
<!DOCTYPE HTML>
<html lang="" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>13 游戏跨服架构进化之路 · 高性能服务器开发 技术专栏</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="easy_coder">
        
        
    
    <link rel="stylesheet" href="../../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-search-pro/search.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-back-to-top-button/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-prism/prism.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-code/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-theme-fexa/fexa.css">
                
            
        

    

    
        
    
        
    
        
    
        
    
        
    
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../../gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="../程序员面试题精讲/" />
    
    
    <link rel="prev" href="12经典游戏服务器端架构概述.html" />
    

    </head>
    <body>
        
<div class="book">
	<div class="header-inner">
		<!-- LOGO -->
		<div class="logo"></div>
		<span class="title"></span>

		<!-- Search -->
		
<div id="book-search-input" role="search">
    <input type="text" placeholder="Type to search" />
</div>


		<!-- Nav -->
		<ul class="header-nav">
			
		</ul>
	</div>

	<div class="book-summary">
		<div class="book-summary-title">文档目录</div>
		
		
		<nav role="navigation">
			


<ul class="summary">
    
    

    

    
        
        <li class="header">Part I</li>
        
        
    
        <li class="chapter " data-level="1.1" data-path="../../">
            
                <a href="../../">
            
                    
                    Introduction
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../C++必知必会的知识点/">
            
                <a href="../C++必知必会的知识点/">
            
                    
                    C++必知必会的知识点
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.2.1" data-path="../C++必知必会的知识点/如何成为一名合格的CC++开发者？.html">
            
                <a href="../C++必知必会的知识点/如何成为一名合格的CC++开发者？.html">
            
                    
                    如何成为一名合格的C/C++开发者？
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.2" data-path="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
            
                <a href="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
            
                    
                    不定参数函数实现var_arg系列的宏
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.3" data-path="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
            
                <a href="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
            
                    
                    你一定要搞明白的C函数调用方式与栈原理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.4" data-path="../C++必知必会的知识点/深入理解CC++中的指针.html">
            
                <a href="../C++必知必会的知识点/深入理解CC++中的指针.html">
            
                    
                    深入理解C/C++中的指针
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.5" data-path="../C++必知必会的知识点/详解C++11中的智能指针.html">
            
                <a href="../C++必知必会的知识点/详解C++11中的智能指针.html">
            
                    
                    详解C++11中的智能指针
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.6" data-path="../C++必知必会的知识点/C++17结构化绑定.html">
            
                <a href="../C++必知必会的知识点/C++17结构化绑定.html">
            
                    
                    C++17结构化绑定
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.7" data-path="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
            
                <a href="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
            
                    
                    C++必须掌握的pimpl惯用法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.8" data-path="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
            
                <a href="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
            
                    
                    用Visual Studio调试Linux程序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.9" data-path="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
            
                <a href="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
            
                    
                    如何使用Visual Studio管理和阅读开源项目代码
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.10" data-path="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
            
                <a href="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
            
                    
                    利用cmake工具生成Visual Studio工程文件
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="../多线程/">
            
                <a href="../多线程/">
            
                    
                    多线程
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.3.1" data-path="../多线程/后台C++开发你一定要知道的条件变量.html">
            
                <a href="../多线程/后台C++开发你一定要知道的条件变量.html">
            
                    
                    后台C++开发你一定要知道的条件变量
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.2" data-path="../多线程/整型变量赋值是原子操作吗？.html">
            
                <a href="../多线程/整型变量赋值是原子操作吗？.html">
            
                    
                    整型变量赋值是原子操作吗？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="2.1" data-path="../网络编程/">
            
                <a href="../网络编程/">
            
                    
                    网络编程
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.1.1" data-path="../网络编程/bind函数重难点解析.html">
            
                <a href="../网络编程/bind函数重难点解析.html">
            
                    
                    bind 函数重难点解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.2" data-path="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
            
                <a href="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
            
                    
                    connect 函数在阻塞和非阻塞模式下的行为
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.3" data-path="../网络编程/select函数重难点解析.html">
            
                <a href="../网络编程/select函数重难点解析.html">
            
                    
                    select 函数重难点解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.4" data-path="../网络编程/Linuxepoll模型（含LT模式和ET模式详解）.html">
            
                <a href="../网络编程/Linuxepoll模型（含LT模式和ET模式详解）.html">
            
                    
                    Linux epoll 模型（含LT 模式和 ET 模式详解）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.5" data-path="../网络编程/socket的阻塞模式和非阻塞模式.html">
            
                <a href="../网络编程/socket的阻塞模式和非阻塞模式.html">
            
                    
                    socket 的阻塞模式和非阻塞模式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.6" data-path="../网络编程/非阻塞模式下send和recv函数的返回值.html">
            
                <a href="../网络编程/非阻塞模式下send和recv函数的返回值.html">
            
                    
                    非阻塞模式下 send 和 recv 函数的返回值
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.7" data-path="../网络编程/服务器开发通信协议设计介绍.html">
            
                <a href="../网络编程/服务器开发通信协议设计介绍.html">
            
                    
                    服务器开发通信协议设计介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.8" data-path="../网络编程/TCP协议如何解决粘包、半包问题.html">
            
                <a href="../网络编程/TCP协议如何解决粘包、半包问题.html">
            
                    
                    TCP 协议如何解决粘包、半包问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.9" data-path="../网络编程/网络通信中收发数据的正确姿势.html">
            
                <a href="../网络编程/网络通信中收发数据的正确姿势.html">
            
                    
                    网络通信中收发数据的正确姿势
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.10" data-path="../网络编程/服务器端发数据时，如果对端一直不收，怎么办？.html">
            
                <a href="../网络编程/服务器端发数据时，如果对端一直不收，怎么办？.html">
            
                    
                    服务器端发数据时，如果对端一直不收，怎么办？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="3.1" data-path="../程序员必知必会的网络命令/">
            
                <a href="../程序员必知必会的网络命令/">
            
                    
                    程序员必知必会的网络命令
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.1" data-path="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
            
                <a href="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
            
                    
                    利用telnet命令发电子邮件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2" data-path="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
            
                <a href="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
            
                    
                    做Java或者C++开发都应该知道的lsof命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3" data-path="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
            
                <a href="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
            
                    
                    Linux网络故障排查的瑞士军刀nc命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4" data-path="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
            
                <a href="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
            
                    
                    Linux tcpdump使用详解
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.5" data-path="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
            
                <a href="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
            
                    
                    从抓包的角度分析connect函数的连接过程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6" data-path="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
            
                <a href="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
            
                    
                    服务器开发中网络数据分析与故障排查经验漫谈
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part II</li>
        
        
    
        <li class="chapter " data-level="4.1" data-path="../高性能服务器框架设计/">
            
                <a href="../高性能服务器框架设计/">
            
                    
                    高性能服务器框架设计
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.1" data-path="../高性能服务器框架设计/主线程与工作线程的分工.html">
            
                <a href="../高性能服务器框架设计/主线程与工作线程的分工.html">
            
                    
                    主线程与工作线程的分工
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2" data-path="../高性能服务器框架设计/Reactor模式.html">
            
                <a href="../高性能服务器框架设计/Reactor模式.html">
            
                    
                    Reactor模式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3" data-path="../高性能服务器框架设计/实例：一个服务器程序的架构介绍.html">
            
                <a href="../高性能服务器框架设计/实例：一个服务器程序的架构介绍.html">
            
                    
                    实例：一个服务器程序的架构介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4" data-path="../高性能服务器框架设计/错误码系统的设计.html">
            
                <a href="../高性能服务器框架设计/错误码系统的设计.html">
            
                    
                    错误码系统的设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5" data-path="../高性能服务器框架设计/日志系统的设计.html">
            
                <a href="../高性能服务器框架设计/日志系统的设计.html">
            
                    
                    日志系统的设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6" data-path="../高性能服务器框架设计/如何设计断线自动重连机制.html">
            
                <a href="../高性能服务器框架设计/如何设计断线自动重连机制.html">
            
                    
                    如何设计断线自动重连机制
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.7" data-path="../高性能服务器框架设计/心跳包机制设计详解.html">
            
                <a href="../高性能服务器框架设计/心跳包机制设计详解.html">
            
                    
                    心跳包机制设计详解
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.8" data-path="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
            
                <a href="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
            
                    
                    业务数据处理一定要单独开线程吗
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.9" data-path="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
            
                <a href="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
            
                    
                    C++ 高性能服务器网络框架设计细节
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="5.1" data-path="../服务器开发案例实战/">
            
                <a href="../服务器开发案例实战/">
            
                    
                    服务器开发案例实战
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.1" data-path="../服务器开发案例实战/从零实现一个http服务器.html">
            
                <a href="../服务器开发案例实战/从零实现一个http服务器.html">
            
                    
                    从零实现一个http服务器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2" data-path="../服务器开发案例实战/从零实现一款12306刷票软件.html">
            
                <a href="../服务器开发案例实战/从零实现一款12306刷票软件.html">
            
                    
                    从零实现一款12306刷票软件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3" data-path="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
            
                <a href="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
            
                    
                    从零实现一个邮件收发客户端
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4" data-path="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
            
                <a href="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
            
                    
                    从零开发一个WebSocket服务器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5" data-path="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
            
                <a href="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
            
                    
                    从零学习开源项目系列（一） 从一款多人联机实时对战游戏开始
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6" data-path="../服务器开发案例实战/2最后一战概况.html">
            
                <a href="../服务器开发案例实战/2最后一战概况.html">
            
                    
                    从零学习开源项目系列（二） 最后一战概况
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7" data-path="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
            
                <a href="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
            
                    
                    从零学习开源项目系列（三） CSBattleMgr服务源码研究
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.8" data-path="../服务器开发案例实战/4LogServer源码探究.html">
            
                <a href="../服务器开发案例实战/4LogServer源码探究.html">
            
                    
                    从零学习开源项目系列（四）LogServer源码探究
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part III</li>
        
        
    
        <li class="chapter " data-level="6.1" data-path="../TeamTalk源码解析/">
            
                <a href="../TeamTalk源码解析/">
            
                    
                    TeamTalk IM源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.1" data-path="../TeamTalk源码解析/01TeamTalk介绍.html">
            
                <a href="../TeamTalk源码解析/01TeamTalk介绍.html">
            
                    
                    01 TeamTalk介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.2" data-path="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
            
                <a href="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
            
                    
                    02 服务器端的程序的编译与部署
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.3" data-path="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
            
                <a href="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
            
                    
                    03 服务器端的程序架构介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.4" data-path="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
            
                <a href="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
            
                    
                    04 服务器端db_proxy_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.5" data-path="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
            
                <a href="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
            
                    
                    05 服务器端msg_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6" data-path="../TeamTalk源码解析/06服务器端login_server源码分析.html">
            
                <a href="../TeamTalk源码解析/06服务器端login_server源码分析.html">
            
                    
                    06 服务器端login_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.7" data-path="../TeamTalk源码解析/07服务器端msfs源码分析.html">
            
                <a href="../TeamTalk源码解析/07服务器端msfs源码分析.html">
            
                    
                    07 服务器端msfs源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.8" data-path="../TeamTalk源码解析/08服务器端file_server源码分析.html">
            
                <a href="../TeamTalk源码解析/08服务器端file_server源码分析.html">
            
                    
                    08 服务器端file_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.9" data-path="../TeamTalk源码解析/09服务器端route_server源码分析.html">
            
                <a href="../TeamTalk源码解析/09服务器端route_server源码分析.html">
            
                    
                    09 服务器端route_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10" data-path="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
            
                <a href="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
            
                    
                    10 开放一个TeamTalk测试服务器地址和几个测试账号
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.11" data-path="../TeamTalk源码解析/11pc客户端源码分析.html">
            
                <a href="../TeamTalk源码解析/11pc客户端源码分析.html">
            
                    
                    11 pc客户端源码分析
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="7.1" data-path="../libevent源码深度剖析/">
            
                <a href="../libevent源码深度剖析/">
            
                    
                    libevent源码深度剖析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.1" data-path="../libevent源码深度剖析/libevent源码深度剖析01.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析01.html">
            
                    
                    libevent源码深度剖析01
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.2" data-path="../libevent源码深度剖析/libevent源码深度剖析02.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析02.html">
            
                    
                    libevent源码深度剖析02
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.3" data-path="../libevent源码深度剖析/libevent源码深度剖析03.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析03.html">
            
                    
                    libevent源码深度剖析03
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.4" data-path="../libevent源码深度剖析/libevent源码深度剖析04.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析04.html">
            
                    
                    libevent源码深度剖析04
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.5" data-path="../libevent源码深度剖析/libevent源码深度剖析05.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析05.html">
            
                    
                    libevent源码深度剖析05
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.6" data-path="../libevent源码深度剖析/libevent源码深度剖析06.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析06.html">
            
                    
                    libevent源码深度剖析06
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.7" data-path="../libevent源码深度剖析/libevent源码深度剖析07.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析07.html">
            
                    
                    libevent源码深度剖析07
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.8" data-path="../libevent源码深度剖析/libevent源码深度剖析08.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析08.html">
            
                    
                    libevent源码深度剖析08
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.9" data-path="../libevent源码深度剖析/libevent源码深度剖析09.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析09.html">
            
                    
                    libevent源码深度剖析09
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.10" data-path="../libevent源码深度剖析/libevent源码深度剖析10.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析10.html">
            
                    
                    libevent源码深度剖析10
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.11" data-path="../libevent源码深度剖析/libevent源码深度剖析11.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析11.html">
            
                    
                    libevent源码深度剖析11
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.12" data-path="../libevent源码深度剖析/libevent源码深度剖析12.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析12.html">
            
                    
                    libevent源码深度剖析12
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.13" data-path="../libevent源码深度剖析/libevent源码深度剖析13.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析13.html">
            
                    
                    libevent源码深度剖析13
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.2" data-path="../leveldb源码分析/">
            
                <a href="../leveldb源码分析/">
            
                    
                    leveldb源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.2.1" data-path="../leveldb源码分析/leveldb源码分析1.html">
            
                <a href="../leveldb源码分析/leveldb源码分析1.html">
            
                    
                    leveldb源码分析1
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.2" data-path="../leveldb源码分析/leveldb源码分析2.html">
            
                <a href="../leveldb源码分析/leveldb源码分析2.html">
            
                    
                    leveldb源码分析2
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.3" data-path="../leveldb源码分析/leveldb源码分析3.html">
            
                <a href="../leveldb源码分析/leveldb源码分析3.html">
            
                    
                    leveldb源码分析3
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.4" data-path="../leveldb源码分析/leveldb源码分析4.html">
            
                <a href="../leveldb源码分析/leveldb源码分析4.html">
            
                    
                    leveldb源码分析4
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.5" data-path="../leveldb源码分析/leveldb源码分析5.html">
            
                <a href="../leveldb源码分析/leveldb源码分析5.html">
            
                    
                    leveldb源码分析5
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.6" data-path="../leveldb源码分析/leveldb源码分析6.html">
            
                <a href="../leveldb源码分析/leveldb源码分析6.html">
            
                    
                    leveldb源码分析6
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.7" data-path="../leveldb源码分析/leveldb源码分析7.html">
            
                <a href="../leveldb源码分析/leveldb源码分析7.html">
            
                    
                    leveldb源码分析7
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.8" data-path="../leveldb源码分析/leveldb源码分析8.html">
            
                <a href="../leveldb源码分析/leveldb源码分析8.html">
            
                    
                    leveldb源码分析8
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.9" data-path="../leveldb源码分析/leveldb源码分析9.html">
            
                <a href="../leveldb源码分析/leveldb源码分析9.html">
            
                    
                    leveldb源码分析9
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.10" data-path="../leveldb源码分析/leveldb源码分析10.html">
            
                <a href="../leveldb源码分析/leveldb源码分析10.html">
            
                    
                    leveldb源码分析10
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.11" data-path="../leveldb源码分析/leveldb源码分析11.html">
            
                <a href="../leveldb源码分析/leveldb源码分析11.html">
            
                    
                    leveldb源码分析11
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.12" data-path="../leveldb源码分析/leveldb源码分析12.html">
            
                <a href="../leveldb源码分析/leveldb源码分析12.html">
            
                    
                    leveldb源码分析12
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.13" data-path="../leveldb源码分析/leveldb源码分析13.html">
            
                <a href="../leveldb源码分析/leveldb源码分析13.html">
            
                    
                    leveldb源码分析13
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.14" data-path="../leveldb源码分析/leveldb源码分析14.html">
            
                <a href="../leveldb源码分析/leveldb源码分析14.html">
            
                    
                    leveldb源码分析14
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.15" data-path="../leveldb源码分析/leveldb源码分析15.html">
            
                <a href="../leveldb源码分析/leveldb源码分析15.html">
            
                    
                    leveldb源码分析15
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.16" data-path="../leveldb源码分析/leveldb源码分析16.html">
            
                <a href="../leveldb源码分析/leveldb源码分析16.html">
            
                    
                    leveldb源码分析16
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.17" data-path="../leveldb源码分析/leveldb源码分析17.html">
            
                <a href="../leveldb源码分析/leveldb源码分析17.html">
            
                    
                    leveldb源码分析17
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.18" data-path="../leveldb源码分析/leveldb源码分析18.html">
            
                <a href="../leveldb源码分析/leveldb源码分析18.html">
            
                    
                    leveldb源码分析18
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.19" data-path="../leveldb源码分析/leveldb源码分析19.html">
            
                <a href="../leveldb源码分析/leveldb源码分析19.html">
            
                    
                    leveldb源码分析19
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.20" data-path="../leveldb源码分析/leveldb源码分析20.html">
            
                <a href="../leveldb源码分析/leveldb源码分析20.html">
            
                    
                    leveldb源码分析20
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.21" data-path="../leveldb源码分析/leveldb源码分析21.html">
            
                <a href="../leveldb源码分析/leveldb源码分析21.html">
            
                    
                    leveldb源码分析21
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.22" data-path="../leveldb源码分析/leveldb源码分析22.html">
            
                <a href="../leveldb源码分析/leveldb源码分析22.html">
            
                    
                    leveldb源码分析22
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="8.1" data-path="../Memcached源码分析/">
            
                <a href="../Memcached源码分析/">
            
                    
                    Memcached源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.1" data-path="../Memcached源码分析/00服务器资源调整.html">
            
                <a href="../Memcached源码分析/00服务器资源调整.html">
            
                    
                    00 服务器资源调整
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.2" data-path="../Memcached源码分析/01初始化参数解析.html">
            
                <a href="../Memcached源码分析/01初始化参数解析.html">
            
                    
                    01 初始化参数解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3" data-path="../Memcached源码分析/02网络监听的建立.html">
            
                <a href="../Memcached源码分析/02网络监听的建立.html">
            
                    
                    02 网络监听的建立
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4" data-path="../Memcached源码分析/03网络连接建立.html">
            
                <a href="../Memcached源码分析/03网络连接建立.html">
            
                    
                    03 网络连接建立
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.5" data-path="../Memcached源码分析/04内存初始化.html">
            
                <a href="../Memcached源码分析/04内存初始化.html">
            
                    
                    04 内存初始化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.6" data-path="../Memcached源码分析/05资源初始化.html">
            
                <a href="../Memcached源码分析/05资源初始化.html">
            
                    
                    05 资源初始化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.7" data-path="../Memcached源码分析/06get过程.html">
            
                <a href="../Memcached源码分析/06get过程.html">
            
                    
                    06 get过程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.8" data-path="../Memcached源码分析/07cas属性.html">
            
                <a href="../Memcached源码分析/07cas属性.html">
            
                    
                    07 cas属性
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.9" data-path="../Memcached源码分析/08内存池.html">
            
                <a href="../Memcached源码分析/08内存池.html">
            
                    
                    08 内存池
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.10" data-path="../Memcached源码分析/09连接队列.html">
            
                <a href="../Memcached源码分析/09连接队列.html">
            
                    
                    09 连接队列
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.11" data-path="../Memcached源码分析/10Hash表操作.html">
            
                <a href="../Memcached源码分析/10Hash表操作.html">
            
                    
                    10 Hash表操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.12" data-path="../Memcached源码分析/12set操作.html">
            
                <a href="../Memcached源码分析/12set操作.html">
            
                    
                    12 set操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.13" data-path="../Memcached源码分析/13do_item_alloc操作.html">
            
                <a href="../Memcached源码分析/13do_item_alloc操作.html">
            
                    
                    13 do_item_alloc操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.14" data-path="../Memcached源码分析/14item结构.html">
            
                <a href="../Memcached源码分析/14item结构.html">
            
                    
                    14 item结构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.15" data-path="../Memcached源码分析/15Hash表扩容.html">
            
                <a href="../Memcached源码分析/15Hash表扩容.html">
            
                    
                    15 Hash表扩容
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.16" data-path="../Memcached源码分析/16线程交互.html">
            
                <a href="../Memcached源码分析/16线程交互.html">
            
                    
                    16 线程交互
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.17" data-path="../Memcached源码分析/17状态机.html">
            
                <a href="../Memcached源码分析/17状态机.html">
            
                    
                    17 状态机
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="9.1" data-path="./">
            
                <a href="./">
            
                    
                    游戏开发专题
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.1" data-path="1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
            
                <a href="1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
            
                    
                    1 游戏服务器开发的基本体系与服务器端开发的一些建议
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2" data-path="2网络游戏服务器开发框架设计介绍.html">
            
                <a href="2网络游戏服务器开发框架设计介绍.html">
            
                    
                    2 网络游戏服务器开发框架设计介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3" data-path="3游戏后端开发需要掌握的知识.html">
            
                <a href="3游戏后端开发需要掌握的知识.html">
            
                    
                    3 游戏后端开发需要掌握的知识
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.4" data-path="4关于游戏服务端架构的整理.html">
            
                <a href="4关于游戏服务端架构的整理.html">
            
                    
                    4 关于游戏服务端架构的整理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.5" data-path="5各类游戏对应的服务端架构.html">
            
                <a href="5各类游戏对应的服务端架构.html">
            
                    
                    5 各类游戏对应的服务端架构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.6" data-path="6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
            
                <a href="6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
            
                    
                    6 从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.7" data-path="7QQ游戏百万人同时在线服务器架构实现.html">
            
                <a href="7QQ游戏百万人同时在线服务器架构实现.html">
            
                    
                    7 QQ游戏百万人同时在线服务器架构实现
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.8" data-path="8大型多人在线游戏服务器架构设计.html">
            
                <a href="8大型多人在线游戏服务器架构设计.html">
            
                    
                    8 大型多人在线游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.9" data-path="9百万用户级游戏服务器架构设计.html">
            
                <a href="9百万用户级游戏服务器架构设计.html">
            
                    
                    9 百万用户级游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.10" data-path="10十万在线的WebGame的数据库设计思路.html">
            
                <a href="10十万在线的WebGame的数据库设计思路.html">
            
                    
                    10 十万在线的WebGame的数据库设计思路
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.11" data-path="11一种高性能网络游戏服务器架构设计.html">
            
                <a href="11一种高性能网络游戏服务器架构设计.html">
            
                    
                    11 一种高性能网络游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.12" data-path="12经典游戏服务器端架构概述.html">
            
                <a href="12经典游戏服务器端架构概述.html">
            
                    
                    12 经典游戏服务器端架构概述
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="9.1.13" data-path="13游戏跨服架构进化之路.html">
            
                <a href="13游戏跨服架构进化之路.html">
            
                    
                    13 游戏跨服架构进化之路
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part IV</li>
        
        
    
        <li class="chapter " data-level="10.1" data-path="../程序员面试题精讲/">
            
                <a href="../程序员面试题精讲/">
            
                    
                    程序员面试题精讲
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.1.1" data-path="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
            
                <a href="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
            
                    
                    腾讯后台开发实习生技能要求
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.2" data-path="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
            
                <a href="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
            
                    
                    聊聊如何拿大厂的 offer
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.3" data-path="../程序员面试题精讲/网络通信题目集锦.html">
            
                <a href="../程序员面试题精讲/网络通信题目集锦.html">
            
                    
                    网络通信题目集锦
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.4" data-path="../程序员面试题精讲/我面试后端开发经理的经历.html">
            
                <a href="../程序员面试题精讲/我面试后端开发经理的经历.html">
            
                    
                    我面试后端开发经理的经历
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.5" data-path="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
            
                <a href="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
            
                    
                    Linux C/C++后端开发面试问哪些问题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.2" data-path="../职业规划/">
            
                <a href="../职业规划/">
            
                    
                    职业规划
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.2.1" data-path="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
            
                <a href="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
            
                    
                    给工作 4 年迷茫的程序员们的一点建议
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.2.2" data-path="../职业规划/聊聊技术人员的常见的职业问题.html">
            
                <a href="../职业规划/聊聊技术人员的常见的职业问题.html">
            
                    
                    聊聊技术人员的常见的职业问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.2.3" data-path="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
            
                <a href="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
            
                    
                    写给那些傻傻想做服务器开发的朋友
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.3" data-path="../自我提升与开源代码/">
            
                <a href="../自我提升与开源代码/">
            
                    
                    自我提升与开源代码
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.3.1" data-path="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
            
                <a href="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
            
                    
                    2020 年好好读一读开源代码吧
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.4" data-path="../后端开发相关的书籍/">
            
                <a href="../后端开发相关的书籍/">
            
                    
                    后端开发相关的书籍
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.4.1" data-path="../后端开发相关的书籍/后台开发应该读的书.html">
            
                <a href="../后端开发相关的书籍/后台开发应该读的书.html">
            
                    
                    后台开发应该读的书
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.5" data-path="../程序员的简历/">
            
                <a href="../程序员的简历/">
            
                    
                    程序员的简历
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.5.1" data-path="../程序员的简历/程序员如何写简历.html">
            
                <a href="../程序员的简历/程序员如何写简历.html">
            
                    
                    程序员如何写简历
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.6" data-path="../程序员的薪资与年终奖那些事儿/">
            
                <a href="../程序员的薪资与年终奖那些事儿/">
            
                    
                    程序员的薪资与年终奖那些事儿
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.6.1" data-path="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
            
                    
                    技术面试与HR谈薪资技巧
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.6.2" data-path="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
            
                    
                    聊一聊程序员如何增加收入
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.6.3" data-path="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
            
                    
                    谈一谈年终奖
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.7" data-path="../程序员的烦心事/">
            
                <a href="../程序员的烦心事/">
            
                    
                    程序员的烦心事
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.7.1" data-path="../程序员的烦心事/拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？.html">
            
                <a href="../程序员的烦心事/拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？.html">
            
                    
                    拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.7.2" data-path="../程序员的烦心事/我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？.html">
            
                <a href="../程序员的烦心事/我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？.html">
            
                    
                    我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.8" data-path="../作者的故事/">
            
                <a href="../作者的故事/">
            
                    
                    作者的故事
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.8.1" data-path="../作者的故事/我的2019.html">
            
                <a href="../作者的故事/我的2019.html">
            
                    
                    我的 2019
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.8.2" data-path="../作者的故事/我是如何年薪五十万的.html">
            
                <a href="../作者的故事/我是如何年薪五十万的.html">
            
                    
                    我是如何年薪五十万的
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            Published with GitBook
        </a>
    </li>
</ul>


		</nav>
		
		
	</div>

	<!-- Content nav -->
	<div class="book-anchor">
		<div class="book-anchor-title">在这篇文章中:</div>
		<div class="book-anchor-body">

		</div>
	</div>

	<div class="book-body">
		
		<div class="body-inner">
			
			

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="../.." >13 游戏跨服架构进化之路</a>
    </h1>
</div>




			<div class="page-wrapper" tabindex="-1" role="main">
				<div class="page-inner">
					
<div id="book-search-results">
    <div class="search-noresults">
    
					<section class="normal markdown-section">
						
						<div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><li><span class="title-icon "></span><a href="#13-&#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;"><b></b>13 &#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;</a></li><ul><ul><li><span class="title-icon "></span><a href="#1&#x80CC;&#x666F;"><b></b>1.&#x80CC;&#x666F;</a></li><li><span class="title-icon "></span><a href="#2&#x8BBE;&#x8BA1;&#x76EE;&#x6807;"><b></b>2.&#x8BBE;&#x8BA1;&#x76EE;&#x6807;</a></li><li><span class="title-icon "></span><a href="#3&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;"><b></b>3.&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;</a></li><li><span class="title-icon "></span><a href="#4&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;"><b></b>4.&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;</a></li><li><span class="title-icon "></span><a href="#5&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;"><b></b>5.&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;</a></li><li><span class="title-icon "></span><a href="#6&#x5C0F;&#x7ED3;"><b></b>6.&#x5C0F;&#x7ED3;</a></li></ul></ul></ul></div><h1 id="13-&#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;"><a name="13-&#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;" class="anchor-navigation-ex-anchor" href="#13-&#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;"><i class="fa fa-link" aria-hidden="true"></i></a>13 &#x6E38;&#x620F;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FDB;&#x5316;&#x4E4B;&#x8DEF;</h1>
<p> &#x6C5F;&#x8D35;&#x9F99;&#xFF0C;&#x6E38;&#x620F;&#x884C;&#x4E1A;&#x4ECE;&#x4E1A;8&#x5E74;&#xFF0C;&#x5386;&#x4EFB;&#x591A;&#x6B3E;&#x6E38;&#x620F;&#x9879;&#x76EE;&#x670D;&#x52A1;&#x5668;&#x4E3B;&#x7A0B;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x8D1F;&#x8D23;&#x4EBA;&#x3002; &#x5173;&#x6CE8;&#x6E38;&#x620F;&#x670D;&#x52A1;&#x5668;&#x67B6;&#x6784;&#x53CA;&#x4F18;&#x5316;&#xFF0C;&#x76D1;&#x63A7;&#x9884;&#x8B66;&#xFF0C;&#x667A;&#x80FD;&#x8FD0;&#x7EF4;&#xFF0C;&#x6570;&#x636E;&#x7EDF;&#x8BA1;&#x5206;&#x6790;&#x7B49;&#x3002;</p>
<h3 id="1&#x80CC;&#x666F;"><a name="1&#x80CC;&#x666F;" class="anchor-navigation-ex-anchor" href="#1&#x80CC;&#x666F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.&#x80CC;&#x666F;</h3>
<p>&#x200B;    &#x867D;&#x7136;&#x6E38;&#x620F;&#x5E02;&#x573A;&#x7ADE;&#x4E89;&#x6FC0;&#x70C8;&#xFF0C;&#x4EA7;&#x54C1;&#x683C;&#x5C40;&#x53D8;&#x52A8;&#x8F83;&#x5927;,&#x4F46;&#x6E38;&#x620F;&#x4EA7;&#x4E1A;&#x4E00;&#x76F4;&#x5904;&#x4E8E;&#x7A33;&#x6B65;&#x589E;&#x957F;&#x9636;&#x6BB5;&#xFF0C;&#x65E0;&#x8BBA;&#x662F;&#x5728;&#x7AEF;&#x6E38;&#xFF0C;&#x9875;&#x6E38;&#xFF0C;&#x624B;&#x6E38;&#x8FD8;&#x662F;&#x5DF2;&#x7ECF;&#x521D;&#x9732;&#x7AEF;&#x502A;&#x7684;H5&#x6E38;&#x620F;&#x3002;&#x53EF;&#x4EE5;&#x9884;&#x89C1;&#xFF0C;&#x6E38;&#x620F;&#x7C7B;&#x578B;&#x4E2D;&#xFF0C;MMOARPG&#x6E38;&#x620F;&#x4ECD;&#x7136;&#x4F1A;&#x662F;&#x5F15;&#x9886;&#x5E02;&#x573A;&#x7684;&#x4E3B;&#x6D41;&#x8D8B;&#x52BF;&#xFF0C;&#x8D21;&#x732E;&#x7740;&#x5927;&#x90E8;&#x5206;&#x6D41;&#x6C34;&#xFF0C;&#x5E02;&#x573A;&#x4E0A;&#x4E5F;&#x4ECD;&#x7136;&#x5728;&#x4E0D;&#x65AD;&#x6D8C;&#x73B0;&#x7CBE;&#x54C1;&#x3002;&#x7814;&#x53D1;&#x56E2;&#x961F;&#x5BF9;MMO&#x6E38;&#x620F;&#x7684;&#x63A2;&#x7D22;&#x4ECE;&#x6765;&#x672A;&#x95F4;&#x65AD;&#x8FC7;,&#x4ECE;&#x4ED8;&#x8D39;&#x6A21;&#x5F0F;&#x7684;&#x6539;&#x53D8;&#xFF0C;&#x5230;&#x9898;&#x6750;&#x591A;&#x5143;&#x5316;&#xFF0C;&#x6B21;&#x65F6;&#x4EE3;&#x7684;&#x89C6;&#x89C9;&#x6548;&#x679C;&#xFF0C;&#x66F4;&#x6210;&#x719F;&#x7684;&#x73A9;&#x6CD5;&#x53CA;&#x6570;&#x503C;&#x4F53;&#x7CFB;&#xFF0C;&#x672C;&#x6587;&#x4E3B;&#x8981;&#x9488;&#x5BF9;&#x8DE8;&#x670D;&#x73A9;&#x6CD5;&#x4E0A;&#x7684;&#x63A2;&#x7D22;&#x548C;&#x5B9E;&#x73B0;&#x505A;&#x4E00;&#x4E9B;&#x601D;&#x8003;&#x548C;&#x5206;&#x6790;&#x3002;
&#x200B;    &#x6839;&#x636E;2016&#x5E74;&#x300A;&#x4E2D;&#x56FD;&#x6E38;&#x620F;&#x4EA7;&#x4E1A;&#x62A5;&#x544A;&#x300B;&#x6570;&#x636E;&#x663E;&#x793A;&#xFF0C;&#x968F;&#x7740;&#x6E38;&#x620F;&#x4EBA;&#x53E3;&#x7EA2;&#x5229;&#x9010;&#x6E10;&#x6D88;&#x5931;&#xFF0C;&#x83B7;&#x53D6;&#x7528;&#x6237;&#x7684;&#x6210;&#x672C;&#x5C45;&#x9AD8;&#x4E0D;&#x4E0B;&#xFF0C;&#x51E0;&#x5E74;&#x6765;&#x81F3;&#x5C11;&#x7FFB;&#x4E86;&#x5341;&#x500D;&#x4EE5;&#x4E0A;&#xFF0C;&#x76EE;&#x524D;&#x5E73;&#x5747;&#x5BFC;&#x91CF;&#x6210;&#x672C;&#x9875;&#x6E38;&#x4E3A;10~15&#x5143;/&#x4EBA;&#xFF0C;&#x624B;&#x6E38;&#x5728;15~20&#x5143;/&#x4EBA;&#xFF0C;&#x5176;&#x4E2D;IOS&#x4E0A;&#x6210;&#x672C;30~50&#x5143;/&#x4EBA;,&#x201C;&#x6D17;&#x201D;&#x7528;&#x6237;&#x6A21;&#x5F0F;&#x7684;&#x6548;&#x679C;&#x6B63;&#x5728;&#x53D8;&#x5F97;&#x5FAE;&#x5F31;&#xFF0C;&#x7528;&#x6237;&#x6D41;&#x5931;&#x4E25;&#x91CD;&#x3002;&#x8BA9;&#x6211;&#x4EEC;&#x5148;&#x6765;&#x770B;&#x770B;&#x6EDA;&#x670D;&#x73A9;&#x6CD5;&#x7684;&#x5C40;&#x9650;&#x6027;&#xFF0C;&#x6EDA;&#x670D;&#x6D17;&#x91CF;&#x6A21;&#x5F0F;&#x4E0B;&#x5B58;&#x5728;&#x7740;&#x5982;&#x4E0B;&#x7684;&#x5F0A;&#x7AEF;&#xFF1A;</p>
<p><img src="../imgs/game72.png" alt=""></p>
<h3 id="2&#x8BBE;&#x8BA1;&#x76EE;&#x6807;"><a name="2&#x8BBE;&#x8BA1;&#x76EE;&#x6807;" class="anchor-navigation-ex-anchor" href="#2&#x8BBE;&#x8BA1;&#x76EE;&#x6807;"><i class="fa fa-link" aria-hidden="true"></i></a>2.&#x8BBE;&#x8BA1;&#x76EE;&#x6807;</h3>
<p>&#x200B;    &#x5728;&#x4E0A;&#x8FF0;&#x80CC;&#x666F;&#x4E0B;&#xFF0C;&#x4E00;&#x6B3E;&#x957F;&#x7559;&#x5B58;&#xFF0C;&#x4F4E;&#x6D41;&#x5931;&#x7684;&#x7CBE;&#x54C1;&#x6E38;&#x620F;&#x5C31;&#x6210;&#x4E86;&#x5E73;&#x53F0;&#x65B9;&#xFF0C;&#x6E20;&#x9053;&#x5546;&#xFF0C;&#x7814;&#x53D1;&#x65B9;&#x8FFD;&#x6367;&#x7684;&#x76EE;&#x6807;&#xFF0C;&#x8BBE;&#x60F3;&#x4E00;&#x4E0B;&#xFF0C;&#x5982;&#x679C;&#x8BA9;&#x6240;&#x6709;&#x670D;&#x52A1;&#x5668;&#x73A9;&#x5BB6;&#x901A;&#x8FC7;&#x201C;&#x8DE8;&#x57DF;&#x4F53;&#x7CFB;&#x201D;&#x5B9E;&#x73B0;&#x81EA;&#x7531;&#x7545;&#x901A;&#x4EA4;&#x4E92;&#xFF0C;&#x5728;&#x6B64;&#x57FA;&#x7840;&#x4E0A;&#xFF0C;&#x73A9;&#x5BB6;&#x53EF;&#x4EE5;&#x4F53;&#x9A8C;&#x5230;&#x524D;&#x6240;&#x672A;&#x6709;&#x7684;&#x201C;&#x56FD;&#x6218;&#x7CFB;&#x7EDF;&#x201D;&#x2014;&#x2014;7&#xD7;24&#x5C0F;&#x65F6;&#x663C;&#x591C;&#x4E0D;&#x505C;&#x670D;&#x7684;&#x56FD;&#x5BB6;&#x6218;&#x4E89;&#xFF0C;&#x968F;&#x65F6;&#x5F00;&#x6218;&#xFF1B;&#x7A81;&#x7834;&#x5355;&#x5730;&#x56FE;&#x627F;&#x8F7D;&#x5BB9;&#x91CF;&#x6781;&#x9650;&#x7684;&#x56FD;&#x6218;&#x5BF9;&#x51B3;&#xFF0C;&#x5E26;&#x6765;&#x771F;&#x6B63;&#x4E07;&#x4EBA;&#x56FD;&#x6218;&#x7684;&#x523A;&#x6FC0;&#x4F53;&#x9A8C;&#xFF0C;&#x5F62;&#x6210;&#x5168;&#x533A;&#x73A9;&#x5BB6;&#x80FD;&#x591F;&#x4E92;&#x52A8;&#x7684;&#x6E38;&#x620F;&#x793E;&#x4EA4;&#x73AF;&#x5883;&#x3002;&#x4F9D;&#x6258;&#x5E73;&#x53F0;&#x8FD0;&#x8425;&#x6765;&#x6253;&#x9020;&#x4E00;&#x6B3E;&#x771F;&#x6B63;&#x610F;&#x4E49;&#x4E0A;&#x6446;&#x8131;&#x4F20;&#x7EDF;&#x6E38;&#x620F;&#x8FD0;&#x8425;&#x6A21;&#x5F0F;&#x7684;&#x5168;&#x65B0;&#x4EA7;&#x54C1;&#xFF0C;&#x4E3A;&#x5E73;&#x53F0;&#x5438;&#x7EB3;&#x8DB3;&#x591F;&#x7684;&#x5E02;&#x573A;&#x4EFD;&#x989D;&#xFF0C;&#x5927;&#x5E45;&#x964D;&#x4F4E;&#x6D41;&#x5931;&#x7387;&#x3002;
&#x200B;    &#x6211;&#x4EEC;&#x7684;&#x84DD;&#x56FE;&#x662F;&#x5F00;&#x521B;&#x201C;1=1000&#x201D;&#x6A21;&#x5F0F;&#xFF0C;&#x8BA9;&#x6240;&#x6709;&#x73A9;&#x5BB6;&#xFF0C;&#x8EAB;&#x5904;&#x4E00;&#x4E2A;&#x670D;&#x52A1;&#x5668;&#x5374;&#x5982;&#x540C;&#x540C;&#x65F6;&#x5B58;&#x5728;&#x4E8E;&#x6240;&#x6709;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x8FD9;&#x79CD;&#x6253;&#x7834;&#x670D;&#x52A1;&#x5668;&#x5C4F;&#x969C;&#x7684;&#x8BBE;&#x5B9A;&#xFF0C;&#x675C;&#x7EDD;&#x4E86;&#x6E38;&#x620F;&#x51FA;&#x73B0;&#x201C;&#x88AB;&#x8FEB;&#x6EDA;&#x670D;&#x201D;&#x73B0;&#x8C61;&#x51FA;&#x73B0;&#xFF0C;&#x73A9;&#x5BB6;&#x4E0D;&#x7528;&#x518D;&#x62C5;&#x5FC3;&#x9B3C;&#x670D;&#x4EBA;&#x70DF;&#x7A00;&#x5C11;&#xFF0C;&#x4E0D;&#x7528;&#x62C5;&#x5FC3;&#x4EA4;&#x6613;&#x6240;&#x4E00;&#x65E0;&#x6240;&#x6709;&#xFF0C;&#x6240;&#x6709;&#x7684;&#x6570;&#x636E;&#x5171;&#x4EAB;&#xFF0C;&#x8BA9;&#x73A9;&#x5BB6;&#x8F7B;&#x677E;Hold&#x4F4F;&#x5168;&#x4E16;&#x754C;&#x3002;<img src="" alt="img"></p>
<p><img src="../imgs/game74.webp" alt=""></p>
<h3 id="3&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;"><a name="3&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;" class="anchor-navigation-ex-anchor" href="#3&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;"><i class="fa fa-link" aria-hidden="true"></i></a>3.&#x8FDB;&#x5316;&#x8FC7;&#x7A0B;</h3>
<p>&#x200B;    &#x9879;&#x76EE;&#x7EC4;&#x90A3;&#x65F6;&#x9762;&#x4E34;&#x7684;&#x73B0;&#x72B6;&#x662F;&#x6E38;&#x620F;&#x5404;&#x79CD;&#x6863;&#x671F;&#x8BA1;&#x5212;&#x3001;&#x5BA3;&#x4F20;&#x63A8;&#x5E7F;&#x5B89;&#x6392;&#x90FD;&#x5DF2;&#x7ECF;&#x5C31;&#x7EEA;&#xFF0C;&#x4E24;&#x4E2A;&#x6708;&#x540E;&#x8BE5;&#x72EC;&#x4EE3;&#x9879;&#x76EE;&#x8981;&#x5728;&#x817E;&#x8BAF;&#x5E73;&#x53F0;&#x6309;&#x65F6;&#x4E0A;&#x7EBF;&#xFF0C;&#x5F00;&#x53D1;&#x4E0D;&#x80FD;&#x56E0;&#x5F15;&#x5165;&#x8DE8;&#x670D;&#x673A;&#x5236;&#x800C;&#x5BFC;&#x81F4;&#x6240;&#x6709;&#x5B8C;&#x6210;&#x5EA6;100%&#x7684;&#x529F;&#x80FD;&#x90FD;&#x8981;&#x53BB;&#x5206;&#x522B;&#x53BB;&#x589E;&#x52A0;&#x8DE8;&#x670D;&#x7684;&#x652F;&#x6301;&#xFF0C;&#x800C;&#x6280;&#x672F;&#x4EBA;&#x5458;&#x5728;&#x8DE8;&#x670D;&#x529F;&#x80FD;&#x5F00;&#x53D1;&#x8FD9;&#x5757;&#x7ECF;&#x9A8C;&#x7684;&#x79EF;&#x7D2F;&#x4E0A;&#x4E5F;&#x4E0D;&#x5145;&#x5206;&#x3002;
&#x6280;&#x672F;&#x5C0F;&#x7EC4;&#x5206;&#x6790;&#x4E86;&#x65F6;&#x4E0B;&#x9879;&#x76EE;&#x7684;&#x73B0;&#x72B6;&#xFF0C;&#x8DE8;&#x670D;&#x4E1A;&#x52A1;&#x9700;&#x6C42;&#x53CA;&#x73B0;&#x6709;&#x7684;&#x6846;&#x67B6;&#x7ED3;&#x6784;&#xFF0C;&#x660E;&#x786E;&#x4E86;&#x51E0;&#x70B9;&#x539F;&#x5219;&#xFF1A; 
&#x200B;    1.&#x4E3A;&#x4E86;&#x5B9E;&#x73B0;&#x8DE8;&#x670D;&#xFF0C;&#x6E38;&#x620F;&#x4EE3;&#x7801;&#x4ECE;&#x5E95;&#x5C42;&#x67B6;&#x6784;&#x5230;&#x4E0A;&#x5C42;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x7684;&#x4EE3;&#x7801;&#x6539;&#x52A8;&#x6210;&#x672C;&#x5C3D;&#x91CF;&#x964D;&#x4F4E;
&#x200B;    2.&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x91CC;&#x5C3D;&#x91CF;&#x5C11;&#x5173;&#x5FC3;&#x6216;&#x8005;&#x4E0D;&#x7528;&#x5173;&#x5FC3;&#x662F;&#x5426;&#x5728;&#x672C;&#x670D;&#x6216;&#x8005;&#x8DE8;&#x670D;&#xFF0C;&#x964D;&#x4F4E;&#x5F00;&#x53D1;&#x4EBA;&#x5458;&#x7684;&#x8DE8;&#x670D;&#x529F;&#x80FD;&#x5F00;&#x53D1;&#x590D;&#x6742;&#x5EA6;&#xFF0C;&#x63D0;&#x9AD8;&#x5F00;&#x53D1;&#x7684;&#x6548;&#x7387;&#xFF0C;&#x7F29;&#x77ED;&#x5F00;&#x53D1;&#x5468;&#x671F;&#x3002;
&#x90A3;&#x4E48;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x89E3;&#x51B3;&#x54EA;&#x4E9B;&#x6280;&#x672F;&#x7591;&#x70B9;&#x5462;&#xFF1F;</p>
<p><strong>3.1 &#x5BA2;&#x6237;&#x7AEF;&#x76F4;&#x8FDE;&#x8FD8;&#x662F;&#x670D;&#x52A1;&#x5668;&#x8F6C;&#x53D1;</strong>
    a)&#x5982;&#x679C;&#x76F4;&#x8FDE;&#xFF0C;&#x90A3;&#x4E48;&#xFF0C;&#x8DE8;&#x670D;&#x73A9;&#x6CD5;&#x65F6;&#x5BA2;&#x6237;&#x7AEF;&#x8981;&#x7EF4;&#x6301;&#x4E24;&#x4E2A;&#x8FDE;&#x63A5;&#xFF0C;&#x5728;&#x8DE8;&#x670D;&#x91CC;&#xFF0C;&#x8981;&#x6A21;&#x62DF;&#x73A9;&#x5BB6;&#x767B;&#x9646;&#xFF0C;&#x7ED1;&#x5B9A;session&#x7684;&#x8FC7;&#x7A0B;&#xFF0C;&#x6E38;&#x620F;&#x670D;&#x548C;&#x8DE8;&#x670D;&#x4E24;&#x8FB9;&#x8981;&#x540C;&#x65F6;&#x7EF4;&#x62A4;&#x4E24;&#x4EFD;&#x73A9;&#x5BB6;&#x6570;&#x636E;&#xFF0C;&#x5982;&#x4F55;&#x505A;&#x5230;&#x6570;&#x636E;&#x7684;&#x540C;&#x6B65;&#xFF1F;&#x8DE8;&#x670D;&#x8981;&#x66B4;&#x9732;&#x7ED9;&#x73A9;&#x5BB6;&#xFF0C;&#x9700;&#x8981;&#x6709;&#x516C;&#x7F51;&#x8BBF;&#x95EE;IP&#x548C;&#x7AEF;&#x53E3;&#x3002;&#x5BF9;&#x5BA2;&#x6237;&#x7AEF;&#x8FDE;&#x63A5;&#x7BA1;&#x7406;&#x6765;&#x8BF4;&#x8F83;&#x590D;&#x6742;&#x3002;
    b)&#x5982;&#x679C;&#x901A;&#x8FC7;&#x5927;&#x533A;&#x670D;&#x52A1;&#x5668;&#x6D88;&#x606F;&#x8F6C;&#x53D1;&#xFF0C;&#x90A3;&#x4E48;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x505A;RPC&#x901A;&#x4FE1;&#xFF0C;&#x8FDE;&#x63A5;&#x7BA1;&#x7406;&#xFF0C;&#x6D88;&#x606F;&#x9700;&#x989D;&#x5916;&#x505A;&#x4E00;&#x6B65;&#x8DF3;&#x8F6C;&#xFF0C;&#x6027;&#x80FD;&#x80FD;&#x5426;&#x6EE1;&#x8DB3;&#xFF1F;&#x8DE8;&#x4E0D;&#x8DE8;&#x670D;&#xFF0C;&#x5BF9;&#x4E8E;&#x5BA2;&#x6237;&#x7AEF;&#x6765;&#x8BF4;&#x900F;&#x660E;&#xFF0C;&#x8DE8;&#x670D;&#x9690;&#x85CF;&#x5728;&#x5927;&#x533A;&#x4E4B;&#x540E;&#xFF0C;&#x66F4;&#x52A0;&#x5B89;&#x5168;&#xFF0C;&#x4E0D;&#x9700;&#x518D;&#x6D6A;&#x8D39;&#x516C;&#x7F51;IP&#x548C;&#x7AEF;&#x53E3;&#x3002;
    &#x7EFC;&#x5408;&#x8003;&#x8651;&#x4E86;&#x4E0B;&#xFF0C;&#x91C7;&#x7528;&#x4E86;B&#x65B9;&#x6848;&#x3002;</p>
<p><strong>3.1.1 RPC&#x6846;&#x67B6;&#x8BBE;&#x8BA1;&#x9700;&#x6C42;</strong>
    &#x90A3;&#x4E48;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5148;&#x51C6;&#x5907;&#x4E00;&#x5957;&#x9AD8;&#x6027;&#x80FD;&#x8F7B;&#x91CF;&#x7EA7;&#x7684;RPC&#x6846;&#x67B6;&#x3002;
    &#x4E1A;&#x754C;&#x6709;&#x5F88;&#x591A;&#x5178;&#x578B;&#x7684;RPC&#x6846;&#x67B6;&#xFF0C;&#x6BD4;&#x5982;Motan&#x3001;Thrift&#x3001;gRPC&#x3001;Hessian&#x3001;Hprose&#xFF0C;Wildfly,Dubbo,DubboX&#xFF0C;&#x4E3A;&#x4EC0;&#x4E48;&#x6211;&#x4EEC;&#x8FD8;&#x8981;&#x91CD;&#x590D;&#x9020;&#x8F6E;&#x5B50;&#x5462;&#xFF1F;&#x7EFC;&#x5408;&#x8003;&#x8651;&#x4E86;&#x4E0B;&#xFF0C;&#x6846;&#x67B6;&#x8981;&#x6EE1;&#x8DB3;&#x4EE5;&#x4E0B;&#x51E0;&#x70B9;&#x4E1A;&#x52A1;&#x9700;&#x6C42;:
    1.&#x8BE5;&#x6846;&#x67B6;&#x8981;&#x7B80;&#x5355;&#x3001;&#x6613;&#x7528;&#x3001;&#x652F;&#x6301;&#x9AD8;&#x5E76;&#x53D1;&#x7684;&#x8DE8;&#x670D;&#x8BF7;&#x6C42;&#xFF1B;
    2.&#x6839;&#x636E;&#x73B0;&#x6709;&#x7684;&#x6E38;&#x620F;&#x670D;&#x52A1;&#x5668;&#x6846;&#x67B6;&#xFF0C;&#x4F1A;&#x6709;&#x5F88;&#x591A;&#x5B9A;&#x5236;&#x5316;&#x7684;&#x573A;&#x666F;&#xFF1B;
    3.&#x901A;&#x8FC7;NIO TCP&#x957F;&#x8FDE;&#x63A5;&#x83B7;&#x53D6;&#x670D;&#x52A1;&#xFF0C;&#x4F46;&#x65E0;&#x9700;&#x8DE8;&#x8BED;&#x8A00;&#x7684;&#x9700;&#x6C42;&#xFF1B;
    4.&#x652F;&#x6301;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#xFF0C;&#x5F02;&#x6B65;&#x8BF7;&#x6C42;&#xFF0C;&#x5F02;&#x6B65;&#x56DE;&#x8C03;CallBack&#xFF1B;
    5.&#x8981;&#x6709;&#x670D;&#x52A1;&#x53D1;&#x73B0;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x8981;&#x6709;Failfast&#x80FD;&#x529B;&#xFF1B;
    6.&#x5177;&#x5907;&#x8D1F;&#x8F7D;&#x5747;&#x8861;&#xFF0C;&#x5206;&#x7EC4;&#x7B49;&#x8DEF;&#x7531;&#x7B56;&#x7565;&#xFF1B;
    &#x57FA;&#x4E8E;&#x6709;&#x4EE5;&#x4E0A;&#x7684;&#x8BC9;&#x6C42;&#xFF0C;&#x7ED3;&#x5408;&#x56E2;&#x961F;&#x4EE5;&#x524D;&#x7684;&#x5F00;&#x53D1;&#x7ECF;&#x9A8C;&#xFF0C;&#x4E8E;&#x662F;&#x5C31;&#x51B3;&#x5B9A;&#x81EA;&#x4E3B;&#x7814;&#x53D1;&#x3002;
    &#x6211;&#x4EEC;&#x9009;&#x7528;&#x7684;&#x6280;&#x672F;&#x6808;&#x6709; Netty&#x3001;Apache Commons Pool&#x3001;Redis&#x7B49;&#x3002;
    &#x6846;&#x67B6;&#x5206;&#x4E3A;&#x670D;&#x52A1;&#x63D0;&#x4F9B;&#x65B9;(RPC Server)&#x3001;&#x670D;&#x52A1;&#x8C03;&#x7528;&#x65B9;(RPC Client)&#x3001;&#x6CE8;&#x518C;&#x4E2D;&#x5FC3;(Registry)&#x4E09;&#x4E2A;&#x89D2;&#x8272;&#xFF0C;&#x57FA;&#x4E8E;Redis&#x4E3A;&#x670D;&#x52A1;&#x6CE8;&#x518C;&#x4E2D;&#x5FC3;&#xFF0C;&#x901A;&#x8FC7;&#x5176;Pub/Sub&#x5B9E;&#x73B0;&#x670D;&#x52A1;&#x52A8;&#x6001;&#x7684;&#x6CE8;&#x518C;&#x548C;&#x53D1;&#x73B0;&#x3002;Server &#x7AEF;&#x4F1A;&#x5728;&#x670D;&#x52A1;&#x521D;&#x59CB;&#x5316;&#x65F6;&#x5411;Registry &#x6CE8;&#x518C;&#x58F0;&#x660E;&#x6240;&#x63D0;&#x4F9B;&#x7684;&#x670D;&#x52A1;&#xFF1B;Client &#x5411; Registry &#x8BA2;&#x9605;&#x5230;&#x5177;&#x4F53;&#x63D0;&#x4F9B;&#x670D;&#x52A1;&#x7684; Server &#x5217;&#x8868;&#xFF0C;&#x6839;&#x636E;&#x9700;&#x8981;&#x4E0E;&#x76F8;&#x5173;&#x7684; Server &#x5EFA;&#x7ACB;&#x8FDE;&#x63A5;&#xFF0C;&#x8FDB;&#x884C; RPC &#x670D;&#x52A1;&#x8C03;&#x7528;&#x3002;&#x540C;&#x65F6;&#xFF0C;Client &#x901A;&#x8FC7; Registry &#x611F;&#x77E5; Server &#x7684;&#x72B6;&#x6001;&#x53D8;&#x66F4;&#x3002;&#x4E09;&#x8005;&#x7684;&#x4EA4;&#x4E92;&#x5173;&#x7CFB;&#x5982;&#x53F3;&#x56FE;&#xFF1A; </p>
<p><img src="../imgs/game73.png" alt=""></p>
<p>&#x56FE;1&#x3001;RPC&#x6846;&#x67B6;&#x4E09;&#x8005;&#x5173;&#x7CFB;</p>
<p><strong>3.1.2 RPC&#x8BF7;&#x6C42;&#x7684;&#x6709;&#x5E8F;&#x6027;</strong>
    &#x8FDE;&#x63A5;&#x6C60;&#x5728;&#x8BBE;&#x8BA1;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x6BD4;&#x8F83;&#x91CD;&#x8981;&#x7684;&#x662F;&#x8981;&#x8003;&#x8651;&#x8BF7;&#x6C42;&#x7684;&#x987A;&#x5E8F;&#x6027;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x5148;&#x8BF7;&#x6C42;&#x7684;&#x5148;&#x5B8C;&#x6210;&#x3002;
    &#x5982;&#x679C;&#x73A9;&#x5BB6;&#x7684;&#x8DE8;&#x670D;&#x8BF7;&#x6C42;&#x901A;&#x8FC7;&#x4E0D;&#x540C;&#x7684;RPC&#x8FDE;&#x63A5;&#x5E76;&#x53D1;&#x6267;&#x884C;&#xFF0C;&#x5C31;&#x6709;&#x53EF;&#x80FD;&#x5355;&#x4E2A;&#x73A9;&#x5BB6;&#x8BF7;&#x6C42;&#x56E0;&#x9519;&#x5E8F;&#x800C;&#x5BFC;&#x81F4;&#x903B;&#x8F91;&#x77DB;&#x76FE;&#xFF0C;&#x6BD4;&#x5982;&#x73A9;&#x5BB6;&#x79FB;&#x52A8;&#xFF0C;&#x89C1;&#x56FE;2&#xFF1A;</p>
<p><img src="../imgs/game75.png" alt=""></p>
<p>&#x56FE;2&#x3001;&#x73A9;&#x5BB6;&#x79FB;&#x52A8;</p>
<p>&#x200B;    &#x73A9;&#x5BB6;&#x79FB;&#x52A8;&#x662F;&#x5F88;&#x9891;&#x7E41;&#x7684;&#xFF0C;&#x5982;&#x679C;A&#x8BF7;&#x6C42;&#x8BA9;&#x73A9;&#x5BB6;&#x4ECE;&#x4F4D;&#x7F6E;1&#x79FB;&#x52A8;&#x5230;&#x4F4D;&#x7F6E;2&#xFF0C;B&#x8BF7;&#x6C42;&#x4ECE;&#x4F4D;&#x7F6E;2&#x79FB;&#x52A8;&#x5230;&#x4F4D;&#x7F6E;3&#xFF0C;&#x6709;&#x53EF;&#x80FD;B&#x8BF7;&#x6C42;&#x5148;&#x88AB;&#x8DE8;&#x670D;&#x63A5;&#x6536;&#x5904;&#x7406;&#xFF0C;&#x8FD9;&#x5C31;&#x4F1A;&#x4EA7;&#x751F;&#x903B;&#x8F91;&#x95EE;&#x9898;&#x3002; 
&#x200B;    &#x90A3;&#x4E48;&#xFF0C;&#x5982;&#x4F55;&#x505A;&#x5230;&#x8BF7;&#x6C42;&#x7684;&#x6709;&#x5E8F;&#x6027;&#x5462;&#xFF1F;&#x5176;&#x672C;&#x8D28;&#x662F;&#x8BA9;&#x540C;&#x4E00;&#x4EFD;&#x6570;&#x636E;&#x7684;&#x8BBF;&#x95EE;&#x80FD;&#x4E32;&#x884C;&#x5316;&#xFF0C;&#x65B9;&#x6CD5;&#x5C31;&#x662F;&#x8BA9;&#x540C;&#x4E00;&#x4E2A;&#x73A9;&#x5BB6;&#x7684;&#x8DE8;&#x670D;&#x8BF7;&#x6C42;&#x901A;&#x8FC7;&#x540C;&#x4E00;&#x6761;RPC&#x8FDE;&#x63A5;&#x6267;&#x884C;&#xFF0C;&#x52A0;&#x4E0A;&#x903B;&#x8F91;&#x4E0A;&#x7684;&#x6709;&#x6548;&#x6027;&#x9A8C;&#x8BC1;&#xFF0C;&#x5982;&#x56FE;3&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="../imgs/game76.jpeg" alt=""></p>
<p><strong>3.1.3 &#x540C;&#x6B65;RPC&#x5B9E;&#x73B0;&#x7EC6;&#x8282;</strong>
    &#x9650;&#x4E8E;&#x7BC7;&#x5E45;&#xFF0C;&#x8FD9;&#x91CC;&#x53EA;&#x8BB2;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#x7684;RPC&#x8FDE;&#x63A5;&#x6C60;&#x5B9E;&#x73B0;&#x3002;
    &#x540C;&#x6B65;&#x8BF7;&#x6C42;&#x7684;&#x65F6;&#x5E8F;&#x56FE;&#x5982;&#x56FE;4&#xFF1A;</p>
<p><img src="../imgs/game77.webp" alt=""></p>
<p>&#x4E0A;&#x56FE;&#x4E3A;&#x8FDB;&#x5165;&#x8DE8;&#x670D;&#x6218;&#x573A;&#x7684;&#x4E00;&#x6B21;&#x540C;&#x6B65;&#x8BF7;&#x6C42;,&#x573A;&#x666F;&#x5207;&#x6362;&#x63A7;&#x5236;&#x5668;StageControllAction&#x53D1;&#x8D77;&#x8FDB;&#x5165;&#x8DE8;&#x670D;&#x6218;&#x573A;&#x7684;&#x8BF7;&#x6C42;applyChangeByBattlefield(),&#x573A;&#x666F;&#x7BA1;&#x7406;&#x5668;StageControllManager&#x9996;&#x5148;&#x8981;&#x8C03;&#x7528;&#x767B;&#x5F55;&#x8DE8;&#x670D;&#x7684;RPC&#x8BF7;&#x6C42;GameRpcClient.loginCrossServer(LoginCrossServerReq)&#xFF0C;
&#x200B;    &#x8DE8;&#x670D;RPC&#x8BF7;&#x6C42;&#x7684;&#x5DE5;&#x4F5C;&#x6D41;&#x662F;&#x8FD9;&#x6837;&#x7684;:</p>
<pre class="language-"><code>public LoginCrossServerAck loginCrossServer(LoginCrossServerReqreq)throws ServiceException {
    //&#x4ECE;&#x8FDE;&#x63A5;&#x6C60;&#x4E2D;&#x83B7;&#x53D6;&#x4E00;&#x4E2A;&#x8FDE;&#x63A5;
    RpcClient rpcClient = rpcClientPool.getResource(req.getRoleId());
    try {
        //&#x53D1;&#x8D77;&#x4E00;&#x6B21;&#x540C;&#x6B65;RPC&#x8BF7;&#x6C42;
        RpcMsg msg = rpcClient.sendWithReturn(MsgType.RPC_LoginCrossServerReq, req);
        return JSON.parseObject(msg.getContent(), LoginCrossServerAck.class);
    } finally {
        //&#x5C06;&#x8FDE;&#x63A5;&#x653E;&#x56DE;&#x8FDE;&#x63A5;&#x6C60;&#x4E2D;
        rpcClientPool.returnResource(rpcClient);
    }
}
</code></pre><p>&#x200B;    &#x8BE5;&#x8BF7;&#x6C42;&#x7B2C;&#x4E00;&#x6B65;&#x5148;&#x4ECE;&#x8FDE;&#x63A5;&#x6C60;&#x91CC;&#x83B7;&#x53D6;&#x4E00;&#x4E2A;&#x8FDE;&#x63A5;RpcClient rpcClient = rpcClientPool.getResource(roleId),&#x7136;&#x540E;&#x53D1;&#x8D77;&#x4E00;&#x4E2A;&#x540C;&#x6B65;&#x8BF7;&#x6C42;RpcClient.sendWithReturn(),&#x7B49;&#x5F85;&#x76F4;&#x5230;&#x7ED3;&#x679C;&#x8FD4;&#x56DE;&#xFF0C;&#x7136;&#x540E;&#x628A;&#x8D44;&#x6E90;&#x5F52;&#x8FD8;&#x8FDE;&#x63A5;&#x6C60;&#x3002;
&#x200B;    &#x6211;&#x4EEC;&#x91CD;&#x70B9;&#x6765;&#x770B;&#x770B;sendWithReturn&#x4EE3;&#x7801;&#x5B9E;&#x73B0;:</p>
<pre class="language-"><code>private ChannelsocketChannel;
private Map<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>Long,</span> <span class="token attr-name">CountDownLatch</span><span class="token punctuation">&gt;</span></span>watchDog = new ConcurrentHashMap&lt;&gt;();
private Map<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>Long,</span> <span class="token attr-name">RpcMsg</span><span class="token punctuation">&gt;</span></span>responses = new ConcurrentHashMap&lt;&gt;();
/**&#x540C;&#x6B65;&#x8BF7;&#x6C42;*/
public RpcMsg sendWithReturn(intmsgType, Objectmsg) throws ServiceException {
    RpcMsg rpcMsg = RpcMsg.newBuilder().setServer(false).setSync(true).setSeqId(buildSeqId()).        setTimestamp(System.nanoTime()).setType(msgType).setContent(JSON.toJSONString(msg)).build();
    //&#x521B;&#x5EFA;&#x4E00;&#x628A;&#x5171;&#x4EAB;&#x9501;
    CountDownLatch latch = new CountDownLatch(1);
    watchDog.put(rpcMsg.getSeqId(), latch);
    writeRequest(rpcMsg);
    return readRequest(rpcMsg.getSeqId(), latch);
}

/**&#x53D1;&#x9001;&#x6D88;&#x606F;*/
publicvoid writeRequest(RpcMsgmsg)throws ServiceException {
    if (channel.isActive()) {
        channel.writeAndFlush(msg);
    }
}

/**&#x963B;&#x585E;&#x7B49;&#x5F85;&#x8FD4;&#x56DE;*/
protected RpcMsg readRequest(longseqId, CountDownLatchlatch)throws ServiceException {
    try {
        //&#x9501;&#x7B49;&#x5F85;
        if (timeout &lt;= 0) {
            //&#x65E0;&#x9650;&#x7B49;&#x5F85;&#xFF0C;&#x76F4;&#x5230;&#x6709;&#x8FD4;&#x56DE;
            latch.await();
        }
        else {
            //&#x8D85;&#x65F6;&#x7B49;&#x5F85;
            latch.await(timeout, TimeUnit.MILLISECONDS);
        }
    }
    catch (InterruptedExceptione) {
        throw new ServiceException(e);
    }
    //&#x89E3;&#x9501;&#x540E;&#x6216;&#x8005;&#x8D85;&#x65F6;&#x540E;&#x7EE7;&#x7EED;&#x5F80;&#x4E0B;&#x8D70;
    watchDog.remove(seqId);
    RpcMsg response = responses.remove(seqId);
    if (response == null) {
        throw new ServiceException(&quot;read request timeout&quot;);
    }
    return response;
}

//&#x83B7;&#x5F97;&#x9501;
CountDownLatch latch = rpcClient.getCountDownLatch(msg.getSeqId());
if (latch != null) {
    rpcClient.setResponse(msg.getSeqId(), msg);
    //&#x89E3;&#x9501;  
    latch.countDown();
}
</code></pre><p>&#x200B;    &#x6D4B;&#x8BD5;&#x573A;&#x666F;&#x4E3A;&#x5206;&#x522B;&#x5728;&#x8FDE;&#x63A5;&#x6570;&#x5728;1,8,&#x5E76;&#x53D1;&#x6570;1,8&#xFF0C;&#x6570;&#x636E;&#x5927;&#x5C0F;&#x5728;22byte&#xFF0C;94byte&#xFF0C;2504byte&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x505A;&#x6D4B;&#x8BD5;&#xFF0C;&#x6D88;&#x606F;&#x540C;&#x6B65;&#x4F20;&#x8F93;&#xFF0C;&#x539F;&#x6837;&#x8FD4;&#x56DE;,&#x4EE5;&#x4E0B;&#x662F;&#x9488;&#x5BF9;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#x538B;&#x529B;&#x6D4B;&#x8BD5;&#x7684;&#x7ED3;&#x679C;(&#x53D6;&#x5747;&#x503C;):</p>
<table>
<thead>
<tr>
<th>&#x8FDE;&#x63A5;&#x6570;</th>
<th>&#x5E76;&#x53D1;&#x6570;</th>
<th>&#x8BF7;&#x6C42;&#x7C7B;&#x578B;</th>
<th>&#x6570;&#x636E;&#x5927;&#x5C0F;&#xFF08;bytes&#xFF09;</th>
<th>&#x5E73;&#x5747;TPS</th>
<th>&#x5E73;&#x5747;&#x54CD;&#x5E94;&#x65F6;&#x95F4;(ms)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>Sync</td>
<td>22</td>
<td>5917</td>
<td>0.169</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>Sync</td>
<td>22</td>
<td>6849</td>
<td>0.146</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>Sync</td>
<td>22</td>
<td>25125</td>
<td>0.0398</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>Sync</td>
<td>94</td>
<td>20790</td>
<td>0.0481</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>Sync</td>
<td>2504</td>
<td>16260</td>
<td>0.0725</td>
</tr>
</tbody>
</table>
<p><strong>3.2 &#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x4E3B;&#x52A8;&#x63A8;&#xFF0C;&#x8FD8;&#x662F;&#x88AB;&#x52A8;&#x62C9;&#x53D6;</strong>
<strong>3.2.1&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x6A21;&#x5F0F;(Pull)</strong>
    &#x7531;&#x4E8E;&#x6211;&#x4EEC;&#x7684;&#x6E38;&#x620F;&#x670D;&#x52A1;&#x5668;&#x548C;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;&#x4EE3;&#x7801;&#x57FA;&#x672C;&#x4E00;&#x81F4;&#xFF0C;&#x6240;&#x4EE5;&#x53EA;&#x8981;&#x80FD;&#x5728;&#x8DE8;&#x670D;&#x4E2D;&#x83B7;&#x5F97;&#x6E38;&#x620F;&#x529F;&#x80FD;&#x6240;&#x8981;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x90A3;&#x4E48;&#xFF0C;&#x5C31;&#x80FD;&#x5B8C;&#x6210;&#x4EFB;&#x4F55;&#x539F;&#x6709;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x5E76;&#x4E14;&#x6539;&#x9020;&#x6210;&#x672C;&#x57FA;&#x672C;&#x4E3A;&#x96F6;&#xFF0C;&#x6211;&#x4EEC;&#x9009;&#x62E9;&#x4E86;&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x3002;
    &#x8FD9;&#x91CC;&#x8981;&#x63D0;&#x51FA;&#x4E00;&#x4E2A;&#x6982;&#x5FF5;:&#x6570;&#x636E;&#x6E90;&#x7684;&#x76F8;&#x5BF9;&#x6027;&#x3002;
    &#x63D0;&#x4F9B;&#x6570;&#x636E;&#x65B9;&#xFF0C;C&#x5411;B&#x8BF7;&#x6C42;&#x4E00;&#x4EFD;&#x6570;&#x636E;&#xFF0C;B&#x662F;C&#x7684;&#x6570;&#x636E;&#x6E90;&#xFF0C;B&#x5411;A&#x8BF7;&#x6C42;&#x4E00;&#x4EFD;&#x6570;&#x636E;&#xFF0C;A&#x662F;B&#x7684;&#x6570;&#x636E;&#x6E90;&#x3002;</p>
<p><img src="../imgs/game78.png" alt=""></p>
<p>&#x56FE;5&#x3001;&#x6570;&#x636E;&#x6E90;&#x7684;&#x76F8;&#x5BF9;&#x6027;</p>
<p>&#x200B;    &#x4E00;&#x4E2A;&#x73A9;&#x5BB6;&#x8DE8;&#x670D;&#x8FC7;&#x53BB;&#x540E;&#xFF0C;&#x5F80;&#x6E38;&#x620F;&#x539F;&#x670D;&#x62C9;&#x53D6;&#x6570;&#x636E;&#x7684;&#x7EC6;&#x8282;&#x56FE;&#x5982;&#x56FE;6&#xFF1A;</p>
<p><img src="../imgs/game79.png" alt=""></p>
<p>&#x56FE;6&#x3001;&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x6A21;&#x5F0F;</p>
<p>&#x200B;    &#x73A9;&#x5BB6;&#x5148;&#x8DE8;&#x670D;&#x8FC7;&#x53BB;&#xFF0C;loginCrossServer(LoginCrossServerReq)&#xFF0C;&#x7136;&#x540E;&#xFF0C;&#x5728;&#x7528;&#x5230;&#x4EFB;&#x610F;&#x6570;&#x636E;&#x65F6;(&#x4E3B;&#x89D2;&#xFF0C;&#x6280;&#x80FD;&#xFF0C;&#x5750;&#x9A91;&#xFF0C;&#x88C5;&#x5907;&#xFF0C;&#x5BA0;&#x7269;&#x7B49;)&#xFF0C;&#x53CD;&#x5411;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#x5404;&#x4E2A;&#x7CFB;&#x7EDF;&#x7684;&#x6570;&#x636E;&#x3002;
&#x200B;    &#x6211;&#x4EEC;&#x7684;&#x5B9E;&#x73B0;&#x5982;&#x56FE;7&#x6240;&#x793A;:</p>
<p><img src="../imgs/game80.jpeg" alt=""></p>
<p>&#x56FE;7&#x3001;&#x88AB;&#x52A8;&#x62C9;&#x53D6;UML&#x56FE;</p>
<pre class="language-"><code>public abstractclass AbstractCacheRepository<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T,</span> <span class="token attr-name">Kextends</span> <span class="token attr-name">Serializable</span><span class="token punctuation">&gt;</span></span> {
    private final LoadingCache<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>K,</span> <span class="token attr-name">DataWrapper&lt;T</span><span class="token punctuation">&gt;</span></span>&gt;caches;
    public AbstractCacheRepository() {
        Type mySuperClass = this.getClass().getGenericSuperclass();
        Type type = ((ParameterizedType)mySuperClass).getActualTypeArguments()[0];
        AnnotationEntityMaker maker = new AnnotationEntityMaker();
        EntityMapping<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span> entityMapping = maker.make((Class<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span>) type);
        CacheLoader<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>K,</span> <span class="token attr-name">DataWrapper&lt;T</span><span class="token punctuation">&gt;</span></span>&gt; loader = new CacheLoader<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>K,</span> <span class="token attr-name">DataWrapper&lt;T</span><span class="token punctuation">&gt;</span></span>&gt;() {
            @Override
                public DataWrapper<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span> load(K entityId) throws Exception {
                return new DataWrapper<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span>(this.load(entityId, entityId));
            }
            //&#x6839;&#x636E;&#x4E0D;&#x540C;&#x7684;&#x8BBF;&#x95EE;&#x63A5;&#x53E3;&#x8BBF;&#x95EE;&#x6570;&#x636E;
            public T load(Serializable roleId, K entityId) {
                return this.getDataAccessor(roleId).load(entityMapping, roleId, entityId);
            }
            public DataAccessor getDataAccessor(SerializableroleId) {
                return DataContext.getDataAccessorManager().getDataAccess(roleId);
            }
        };
        caches = CacheBuilder.newBuilder().expireAfterAccess(300, TimeUnit.SECONDS).build(loader);
    }
    public T cacheLoad(K entityId) {
        return this.load(entityId);
    }
    private T load(K entityId) {
        return caches.getUnchecked(entityId).getEntity();
    }
}
</code></pre><p>&#x200B;    1) &#x73A9;&#x5BB6;&#x5728;&#x6E38;&#x620F;&#x672C;&#x670D;&#xFF0C;&#x83B7;&#x53D6;Role&#x6570;&#x636E;&#xFF0C;&#x901A;&#x8FC7;RoleRepository.cacheLoad(long roleId)&#xFF0C;&#x5148;&#x4ECE;Cache&#x91CC;&#x8BFB;&#x53D6;&#xFF0C;&#x6CA1;&#x6709;&#xFF0C;&#x5219;&#x8C03;&#x7528;&#x8BBF;&#x95EE;&#x5668;MySQLDataAccessor.load(EntityMapping em,Serializable roleId, K id)&#x4ECE;&#x6570;&#x636E;&#x5E93;&#x8BFB;&#x53D6;&#x6570;&#x636E;&#x3002;
&#x200B;    2) &#x73A9;&#x5BB6;&#x5728;&#x8DE8;&#x670D;&#xFF0C;&#x83B7;&#x53D6;Role&#x6570;&#x636E;&#xFF0C;&#x901A;&#x8FC7;RoleRepository.cacheLoad(long roleId)&#xFF0C;&#x5148;&#x4ECE;Cache&#x91CC;&#x8BFB;&#x53D6;&#xFF0C;&#x6CA1;&#x6709;&#xFF0C;&#x5219;&#x8C03;&#x7528;&#x8BBF;&#x95EE;&#x5668;NetworkDataAccessor.load(EntityMappingem, Serializable roleId, K id)&#xFF0C;&#x901A;&#x8FC7;RPC&#x8FDC;&#x7A0B;&#x540C;&#x6B65;&#x8C03;&#x7528;&#x8BFB;&#x53D6;&#x6570;&#x636E;session.sendRPCWithReturn(),&#x8BE5;&#x65B9;&#x6CD5;&#x7684;&#x5B9E;&#x73B0;&#x53EF;&#x4EE5;&#x53C2;&#x8003;&#x4E0A;&#x8FF0;&#x7684;RpcClient.sendWithReturn()&#xFF0C;&#x76F8;&#x7C7B;&#x4F3C;&#x3002;
&#x200B;    &#x5173;&#x4E8E;&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x7684;&#x4F18;&#x7F3A;&#x70B9;&#x4ECB;&#x7ECD;&#xFF0C;&#x5728;&#x4E0B;&#x6587;&#x53E6;&#x6709;&#x8BBA;&#x8FF0;&#x3002;&#x603B;&#x4E4B;&#xFF0C;&#x7531;&#x4E8E;&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x7684;&#x4E00;&#x4E9B;&#x6211;&#x4EEC;&#x59CB;&#x6599;&#x672A;&#x53CA;&#x7684;&#x7F3A;&#x9677;&#x5B58;&#x5728;&#xFF0C;&#x6210;&#x4E3A;&#x4E86;&#x6211;&#x4EEC;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x5F00;&#x53D1;&#x90E8;&#x5206;&#x529F;&#x80FD;&#x7684;&#x5669;&#x68A6;&#xFF0C;&#x4ECE;&#x9009;&#x62E9;&#x8BE5;&#x6A21;&#x5F0F;&#x65F6;&#x5C31;&#x57CB;&#x4E0B;&#x4E86;&#x4E00;&#x4E2A;&#x5929;&#x5751;&#x3002;</p>
<p><strong>3.2.2&#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x6A21;&#x5F0F;(Push)</strong> 
    &#x4E3A;&#x4E86;&#x89E3;&#x51B3;&#x4E86;&#x4E0A;&#x9762;&#x78B0;&#x5230;&#x7684;&#x4E00;&#x7CFB;&#x5217;&#x95EE;&#x9898;&#xFF0C; &#x5E76;&#x4E14;&#x8FD8;&#x80FD;&#x575A;&#x6301;&#x6700;&#x521D;&#x7684;&#x539F;&#x5219;&#xFF0C;&#x6211;&#x4EEC;&#x505A;&#x4E86;&#x5982;&#x4E0B;&#x51E0;&#x70B9;&#x4F18;&#x5316;
&#x4F18;&#x5316;&#x65B9;&#x6848;&#x6709;&#x5982;&#x4E0B;&#x51E0;&#x70B9;&#xFF1A;
    1.&#x5982;&#x679C;&#x73A9;&#x5BB6;&#x5728;&#x672C;&#x670D;&#xFF0C;&#x548C;&#x8C03;&#x6574;&#x524D;&#x4E00;&#x6837;&#x7684;&#x5904;&#x7406;&#x6D41;&#x7A0B;&#xFF0C;&#x5982;&#x679C;&#x73A9;&#x5BB6;&#x5728;&#x8DE8;&#x670D;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x8BF7;&#x6C42;&#x7684;&#x6307;&#x4EE4;&#xFF0C;&#x53D1;&#x5E03;&#x7684;&#x4E8B;&#x4EF6;&#xFF0C;&#x5F02;&#x6B65;&#x4E8B;&#x4EF6;&#x9700;&#x8981;&#x5728;&#x573A;&#x666F;Stage&#x7EBF;&#x7A0B;&#x5904;&#x7406;&#x7684;&#xFF0C;&#x5C31;&#x8F6C;&#x53D1;&#x5230;&#x8DE8;&#x670D;&#xFF0C;&#x9700;&#x8981;&#x5728;&#x5176;&#x4ED6;&#x4E2A;&#x4EBA;&#x4E1A;&#x52A1;&#x7EBF;&#x7A0B;&#xFF08;bus&#xFF09;,&#x516C;&#x5171;&#x4E1A;&#x52A1;&#x7EBF;&#x7A0B;&#xFF08;public&#xFF09;&#x5904;&#x7406;&#x7684;&#xFF0C;&#x4ECD;&#x65E7;&#x5728;&#x672C;&#x670D;&#x5904;&#x7406;&#x3002;
    2.&#x573A;&#x666F;&#x4E1A;&#x52A1;&#x7EBF;&#x7A0B;&#x4E0D;&#x518D;&#x5141;&#x8BB8;&#x6709;DB&#x64CD;&#x4F5C;
    3.&#x5185;&#x90E8;&#x6307;&#x4EE4;&#x7684;&#x8F6C;&#x53D1;&#x3001;&#x4E8B;&#x4EF6;&#x5206;&#x53D1;&#x7CFB;&#x7EDF;&#x3001;&#x5F02;&#x6B65;&#x4E8B;&#x4EF6;&#x7CFB;&#x7EDF;&#x8981;&#x5728;&#x5E95;&#x5C42;&#x652F;&#x6301;&#x8DE8;&#x670D;
    4.&#x73A9;&#x5BB6;&#x5728;&#x767B;&#x5F55;&#x672C;&#x670D;&#x65F6;&#x5C31;&#x4F1A;&#x6784;PlayerTemplate, &#x573A;&#x666F;&#x7528;&#x5230;&#x7684;&#x6570;&#x636E;&#x4F1A;&#x5B9E;&#x65F6;&#x66F4;&#x65B0;&#xFF0C;&#x73A9;&#x5BB6;&#x53BB;&#x8DE8;&#x670D;&#xFF0C;&#x5219;&#x4F1A;&#x628A;&#x573A;&#x666F;&#x4E2D;&#x7528;&#x5230;&#x7684;&#x6570;&#x636E;PlayerTemplate&#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x7ED9;&#x8DE8;&#x670D;&#x3002;</p>
<p><img src="../imgs/game81.png" alt=""></p>
<p>&#x56FE;8&#x3001;&#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x6A21;&#x5F0F;</p>
<p>&#x200B;    &#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x6A21;&#x5F0F;&#x56FE;&#x793A;&#x663E;&#x793A;&#x5982;&#x56FE;8&#x6240;&#x793A;:</p>
<table>
<thead>
<tr>
<th>&#x65B9;&#x6848;&#x5BF9;&#x6BD4;</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>&#x57FA;&#x672C;&#x53C2;&#x6570;</td>
<td>&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x6A21;&#x5F0F;</td>
<td>&#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x6A21;&#x5F0F;</td>
</tr>
<tr>
<td>&#x6539;&#x52A8;&#x5DE5;&#x4F5C;&#x91CF;</td>
<td>&#x65E2;&#x5B9E;&#x73B0;&#x4E86;&#x539F;&#x5148;&#x7684;&#x65E2;&#x5B9A;&#x76EE;&#x6807;&#xFF0C;&#x6539;&#x52A8;&#x6210;&#x672C;&#x57FA;&#x672C;&#x4E3A;&#x96F6;&#xFF0C;&#x5BF9;&#x4E8E;&#x8FDB;&#x5EA6;&#x7D27;&#x5F20;&#x7684;&#x9879;&#x76EE;&#x6765;&#x8BF4;&#xFF0C;&#x662F;&#x4E2A;&#x6781;&#x5927;&#x7684;&#x8BF1;&#x60D1;</td>
<td>&#x9700;&#x5C4F;&#x853D;&#x5728;Stage&#x7EBF;&#x7A0B;&#x4E2D;&#x9488;&#x5BF9;DB&#x7684;CRUD&#x64CD;&#x4F5C;&#xFF0C;&#x6784;&#x5EFA;PlayerTemplate&#x800C;&#x5F15;&#x53D1;&#x7684;&#x4E00;&#x7CFB;&#x5217;&#x6539;&#x52A8;</td>
</tr>
<tr>
<td>&#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x7684;&#x5185;&#x90E8;&#x6307;&#x4EE4;&#x548C;&#x4E8B;&#x4EF6;&#x5206;&#x53D1;&#x91CF;</td>
<td>&#x7531;&#x4E8E;&#x4E2A;&#x4EBA;&#x4E1A;&#x52A1;&#x6570;&#x636E;&#x548C;&#x573A;&#x666F;&#x4E1A;&#x52A1;&#x6570;&#x636E;&#x90FD;&#x5728;&#x8DE8;&#x670D;&#x5904;&#x7406;&#xFF0C;&#x6240;&#x4EE5;&#x4E0D;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x8DE8;&#x8FDB;&#x7A0B;&#x901A;&#x4FE1;</td>
<td>&#x5BF9;&#x4E8E;&#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x5185;&#x90E8;&#x6307;&#x4EE4;&#xFF0C;&#x4E8B;&#x4EF6;&#x5206;&#x53D1;&#x589E;&#x52A0;&#x4E86;&#x4E00;&#x5B9A;&#x7684;&#x91CF;</td>
</tr>
<tr>
<td>&#x6570;&#x636E;&#x4E2D;&#x5FC3;&#x95EE;&#x9898;</td>
<td>&#x6570;&#x636E;&#x4E2D;&#x5FC3;&#x8FDB;&#x884C;&#x4E86;&#x8F6C;&#x79FB;&#xFF0C;&#x628A;&#x672C;&#x670D;&#x7684;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x7ED9;&#x9501;&#x4F4F;&#x3002;&#x5982;&#x679C;&#x90E8;&#x5206;&#x6570;&#x636E;&#x6CA1;&#x9501;&#x4F4F;&#xFF0C;&#x5C31;&#x4F1A;&#x5BFC;&#x81F4;&#x6570;&#x636E;&#x7684;&#x4E0D;&#x540C;&#x6B65;&#xFF0C;&#x6216;&#x8005;&#x8BF4;&#xFF0C;&#x672C;&#x670D;&#x6570;&#x636E;&#x505A;&#x4E86;&#x66F4;&#x65B0;&#x800C;&#x5BFC;&#x81F4;&#x56DE;&#x6863;&#x7684;&#x98CE;&#x9669;&#x3002;&#x800C;&#x5982;&#x679C;&#x8DE8;&#x670D;&#x5B95;&#x673A;&#xFF0C;&#x5219;&#x6709;5&#x5206;&#x949F;&#x7684;&#x56DE;&#x6863;&#x98CE;&#x9669;</td>
<td>&#x4E0D;&#x53D8;&#x4E0D;&#x8F6C;&#x79FB;&#xFF0C;&#x4ECE;&#x6839;&#x672C;&#x4E0A;&#x89C4;&#x907F;&#x4E86;&#x6570;&#x636E;&#x56DE;&#x6863;&#x7684;&#x98CE;&#x9669;</td>
</tr>
<tr>
<td>&#x901A;&#x4FE1;&#x6570;&#x636E;&#x91CF;</td>
<td>&#x5927;&#x91CF;&#x6570;&#x636E;&#x7684;&#x8FC1;&#x79FB;&#xFF0C;&#x6BD4;&#x5982;&#x8981;&#x83B7;&#x5F97;&#x4E00;&#x4E2A;&#x9053;&#x5177;&#xFF0C;&#x9700;&#x8981;&#x628A;&#x8FD9;&#x4E2A;&#x73A9;&#x5BB6;&#x7684;&#x6240;&#x6709;&#x7684;&#x9053;&#x5177;&#x7684;&#x6570;&#x636E;&#x4ECE;&#x672C;&#x670D;&#x8FC1;&#x79FB;&#x5230;&#x8DE8;&#x670D;&#xFF0C;&#x5927;&#x5927;&#x589E;&#x52A0;&#x7684;&#x4E86;&#x6570;&#x636E;&#x7684;&#x901A;&#x4FE1;&#x91CF;</td>
<td>&#x53EA;&#x628A;&#x8DE8;&#x670D;&#x6240;&#x9700;&#x8981;&#x7684;&#x573A;&#x666F;&#x6570;&#x636E;&#x63A8;&#x9001;&#x8FC7;&#x53BB;&#xFF0C;&#x6570;&#x636E;&#x91CF;&#x5927;&#x5927;&#x964D;&#x4F4E;</td>
</tr>
<tr>
<td>&#x7528;&#x6237;&#x4F53;&#x9A8C;</td>
<td>&#x4E3A;&#x4E86;&#x4E0D;&#x8BA9;&#x4E00;&#x4E9B;&#x6E38;&#x620F;&#x6570;&#x636E;&#x56DE;&#x6863;&#xFF0C;&#x6211;&#x4EEC;&#x4E0D;&#x5F97;&#x4E0D;&#x5BF9;&#x67D0;&#x4E9B;&#x529F;&#x80FD;&#x505A;&#x663E;&#x5F0F;&#x5C4F;&#x853D;&#xFF0C;&#x4F46;&#x8FD9;&#x6837;&#x5E26;&#x6765;&#x7684;&#x4F53;&#x9A8C;&#x5C31;&#x5F88;&#x4E0D;&#x597D;&#xFF0C;&#x5F53;&#x8DE8;&#x670D;&#x540E;&#xFF0C;&#x70B9;&#x51FB;&#x83B7;&#x53D6;&#x90AE;&#x4EF6;&#xFF0C;&#x4F1A;&#x663E;&#x793A;&#x4F60;&#x5728;&#x8DE8;&#x670D;&#x4E0D;&#x5141;&#x8BB8;&#x83B7;&#x53D6;&#x63D0;&#x53D6;&#x9644;&#x4EF6;&#xFF1B;&#x5C4F;&#x853D;&#x516C;&#x4F1A;&#x7684;&#x64CD;&#x4F5C;&#xFF0C;&#x6BD4;&#x5982;&#x516C;&#x4F1A;&#x6350;&#x732E;&#xFF0C;&#x516C;&#x4F1A;&#x9886;&#x5DE5;&#x8D44;&#xFF0C;&#x56E0;&#x4E3A;&#x4E0D;&#x53EF;&#x80FD;&#x628A;&#x6574;&#x4E2A;&#x516C;&#x4F1A;&#x7684;&#x6570;&#x636E;&#x7ED9;&#x540C;&#x6B65;&#x5230;&#x8DE8;&#x670D;&#x4E2D;</td>
<td>&#x6240;&#x6709;&#x7684;&#x529F;&#x80FD;&#x90FD;&#x4E0D;&#x4F1A;&#x88AB;&#x5C4F;&#x853D;</td>
</tr>
<tr>
<td>&#x5F00;&#x53D1;&#x6D3B;&#x52A8;&#x7684;&#x96BE;&#x6613;&#x5EA6;</td>
<td>&#x7531;&#x4E8E;&#x6BCF;&#x4E2A;&#x6E38;&#x620F;&#x533A;&#x7684;&#x6D3B;&#x52A8;&#x7CFB;&#x7EDF;(&#x5F00;&#x670D;&#x6D3B;&#x52A8;&#xFF0C;&#x548C;&#x670D;&#x6D3B;&#x52A8;&#xFF0C;&#x8282;&#x65E5;&#x6D3B;&#x52A8;&#xFF0C;&#x5546;&#x4E1A;&#x5316;&#x51B2;KPI&#x7684;&#x6D3B;&#x52A8;)&#x7684;&#x5DEE;&#x5F02;&#x6027;&#xFF0C;&#x7ED9;&#x7F16;&#x7801;&#x5E26;&#x6765;&#x4E86;&#x5F88;&#x5927;&#x590D;&#x6742;&#x6027;&#x3002;</td>
<td>&#x6D89;&#x53CA;&#x5230;&#x7684;&#x6240;&#x6709;&#x5546;&#x4E1A;&#x5316;&#x6D3B;&#x52A8;&#x7684;&#x529F;&#x80FD;&#x5F00;&#x53D1;&#x548C;&#x672C;&#x670D;&#x4E00;&#x6837;&#x7B80;&#x5355;</td>
</tr>
<tr>
<td>&#x5145;&#x503C;&#x95EE;&#x9898;</td>
<td>&#x5145;&#x503C;&#x56DE;&#x8C03;&#x90FD;&#x662F;&#x5230;&#x6E38;&#x620F;&#x533A;&#x672C;&#x670D;&#xFF0C;&#x90A3;&#x600E;&#x4E48;&#x529E;&#x5462;&#xFF0C;&#x5C31;&#x5FC5;&#x987B;&#x540C;&#x6B65;&#x8FD9;&#x4E2A;&#x6570;&#x636E;&#x5230;&#x8DE8;&#x670D;</td>
<td>&#x5728;&#x5904;&#x7406;&#x5145;&#x503C;&#x56DE;&#x8C03;&#x65F6;&#x4E0D;&#x7528;&#x518D;&#x8003;&#x8651;&#x662F;&#x5426;&#x5728;&#x8DE8;&#x670D;</td>
</tr>
<tr>
<td>RPC&#x6027;&#x80FD;&#x95EE;&#x9898;</td>
<td>&#x56E0;&#x4E3A;&#x8981;&#x8DE8;&#x670D;&#x4ECE;&#x672C;&#x670D;&#x62C9;&#x53D6;&#x6570;&#x636E;&#xFF0C;&#x8FD9;&#x4E2A;&#x8BF7;&#x6C42;&#x5FC5;&#x987B;&#x662F;&#x540C;&#x6B65;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x540C;&#x6B65;&#x7684;RPC&#x8BF7;&#x6C42;&#x7684;&#x9891;&#x7E41;&#x5BFC;&#x81F4;&#x4E86;&#x8DE8;&#x670D;&#x6027;&#x80FD;&#x7684;&#x964D;&#x4F4E;&#xFF0C;&#x7279;&#x522B;&#x662F;&#x5F53;&#x67D0;&#x4E2A;&#x8DE8;&#x670D;&#x6D3B;&#x52A8;&#x521A;&#x5F00;&#x542F;&#x65F6;&#xFF0C;&#x6709;&#x5F88;&#x591A;&#x73A9;&#x5BB6;&#x6D8C;&#x5165;&#x8FD9;&#x4E2A;&#x573A;&#x666F;&#xFF0C;&#x4F1A;&#x53D1;&#x751F;&#x5F88;&#x591A;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#xFF08;role,item,skill,horse,pet,achievement&#x2026;&#xFF09;&#xFF0C;&#x5BFC;&#x81F4;&#x90E8;&#x5206;&#x73A9;&#x5BB6;&#x7684;&#x5361;&#x5728;&#x8DE8;&#x670D;&#x573A;&#x666F;&#x8DF3;&#x8F6C;&#x8FC7;&#x7A0B;&#x4E2D;,&#x5177;&#x4F53;&#x5B9E;&#x73B0;&#x8BF7;&#x53C2;&#x8003;&#x4E0A;&#x8FF0;&#x540C;&#x6B65;&#x8BF7;&#x6C42;&#x4EE3;&#x7801;&#x5B9E;&#x73B0;sendWithReturn</td>
<td>&#x53BB;&#x6389;&#x4E86;&#x8DE8;&#x670D;&#x4ECE;&#x6E38;&#x620F;&#x670D;&#x62C9;&#x6570;&#x636E;&#x7684;&#x9700;&#x6C42;&#xFF0C;&#x6539;&#x6210;&#x4E86;&#x8DE8;&#x670D;&#x65F6;&#x672C;&#x5730;&#x63A8;&#x9001;&#x4E00;&#x6B21;&#x573A;&#x666F;&#x9700;&#x8981;&#x7528;&#x5F97;&#x5230;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x57FA;&#x672C;&#x53BB;&#x6389;&#x4E86;99%&#x540C;&#x6B65;RPC&#x8BF7;&#x6C42;&#x3002;</td>
</tr>
<tr>
<td>&#x6D88;&#x606F;&#x8F6C;&#x53D1;&#x91CF;</td>
<td>&#x9700;&#x8981;&#x628A;&#x6240;&#x6709;&#x73A9;&#x5BB6;&#x7684;&#x8BF7;&#x6C42;&#x90FD;&#x8F6C;&#x53D1;&#x5230;&#x8DE8;&#x670D;&#xFF0C;&#x8F6C;&#x53D1;&#x91CF;&#x975E;&#x5E38;&#x5927;,60+%&#x7684;&#x6D88;&#x606F;&#x5176;&#x5B9E;&#x662F;&#x6CA1;&#x5FC5;&#x8981;&#x8F6C;&#x53D1;&#x5230;&#x8DE8;&#x670D;&#x53BB;&#x5904;&#x7406;&#x7684;</td>
<td>&#x9664;&#x4E86;&#x573A;&#x666F;&#x4E0A;&#x7684;&#x64CD;&#x4F5C;&#x7684;Action&#x8BF7;&#x6C42;&#xFF0C;&#x4E0D;&#x9700;&#x8981;&#x518D;&#x88AB;&#x8F6C;&#x53D1;&#x5230;&#x8DE8;&#x670D;&#x53BB;&#x6267;&#x884C;&#xFF0C;&#x6781;&#x5927;&#x7684;&#x964D;&#x4F4E;&#x4E86;&#x6D88;&#x606F;&#x7684;&#x8F6C;&#x53D1;&#x91CF;</td>
</tr>
</tbody>
</table>
<p>&#x770B;&#x4E0B;&#x4E8B;&#x4EF6;&#x5206;&#x53D1;&#x4EE3;&#x7801;&#x7684;&#x6539;&#x9020;:</p>
<pre class="language-"><code>/**&#x4E8B;&#x4EF6;&#x5206;&#x53D1;&#x5668;*/
public abstract class AbEvent {
    private static AtomicLong seq = new AtomicLong(System.currentTimeMillis());
    /**&#x4E8B;&#x4EF6;&#x8BA2;&#x9605;*/
    public abstract void subscribe();
    /**&#x4E8B;&#x4EF6;&#x76D1;&#x542C;&#x5668;*/
    protected abstract List<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>HandlerWrapper</span><span class="token punctuation">&gt;</span></span> getHandlerPipeline();
    /**&#x4E8B;&#x4EF6;&#x5206;&#x53D1;*/
    protected void dispatch() {
        id = seq.incrementAndGet();
        List<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>HandlerWrapper</span><span class="token punctuation">&gt;</span></span> handlerList = this.getHandlerPipeline();
        DispatchEventReq<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>AbEvent</span><span class="token punctuation">&gt;</span></span> req = new DispatchEventReq&lt;&gt;();
        req.setRoleId(roleId);
        req.setEntity(this);
        for (HandlerWrapper wrapper : handlerList) {
            byte group = wrapper.getGroup();
            if (group == 0) {
                // &#x540C;&#x7EBF;&#x7A0B;&#x4E32;&#x884C;&#x6267;&#x884C;
                eventManager.syncCall(wrapper, this);
            }
            else {
                // &#x975E;&#x540C;&#x7EBF;&#x7A0B;&#x5F02;&#x6B65;&#x6267;&#x884C;,&#x53EF;&#x80FD;&#x53BB;&#x8FDC;&#x7A0B;&#x6267;&#x884C;
                this.advancedAsyncCall(req, wrapper);
            }
        }
    }
}

/** &#x8DE8;&#x670D;&#x63A5;&#x6536;&#x6D88;&#x606F;&#x5206;&#x53D1;&#x7684;&#x4E8B;&#x4EF6; */
@Override
public <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span> void dispatchEvent(Session session, DispatchEventReq<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>T</span><span class="token punctuation">&gt;</span></span> msg) {
    T event = msg.getEntity();
    List<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>String</span><span class="token punctuation">&gt;</span></span> list = msg.getHandlerList();
    long roleId = msg.getRoleId();
    for (String e : list) {
        HandlerWrapper wrapper = eventManager.getHandlerWrapper(e, event);
        eventManager.asyncCall(roleId, wrapper, event);
    }
}
</code></pre><p>&#x200B;    &#x5982;&#x4E0B;&#x56FE;&#xFF0C;&#x4E3E;&#x4E2A;&#x4F8B;&#x5B50;&#xFF0C;&#x5728;&#x8DE8;&#x670D;&#x602A;&#x7269;&#x6B7B;&#x4EA1;&#x540E;&#xFF0C;&#x4F1A;&#x629B;&#x51FA; MonsterDeadEvent&#x4E8B;&#x4EF6;&#xFF0C;&#x5728;&#x8DE8;&#x670D;&#x8FDB;&#x7A0B;&#x76F4;&#x63A5;&#x5904;&#x7406;&#x573A;&#x666F;&#x7684;&#x76D1;&#x542C;&#x5BF9;&#x5E94;&#x7684;&#x903B;&#x8F91;&#xFF1A; &#x573A;&#x666F;&#x4E2D;&#x9053;&#x5177;&#x6389;&#x843D;&#xFF0C;&#x5C38;&#x4F53;&#x5904;&#x7406;&#xFF1B;&#x5176;&#x4ED6;&#x7684;&#x76D1;&#x542C;&#x903B;&#x8F91;&#x629B;&#x56DE;&#x6E38;&#x620F;&#x670D;&#x5904;&#x7406;&#xFF0C;&#x6839;&#x636E;&#x8FD9;&#x4E8B;&#x4EF6;,&#x4EFB;&#x52A1;&#x6A21;&#x5757;&#x5904;&#x7406;&#x5B8C;&#x6210;&#x4EFB;&#x52A1;&#xFF0C;&#x83B7;&#x5F97;&#x5956;&#x52B1;;&#x6210;&#x5C31;&#x6A21;&#x5757;&#x5904;&#x7406;&#x5B8C;&#x6210;&#x6210;&#x5C31;&#xFF0C;&#x83B7;&#x5F97;&#x5956;&#x52B1;; &#x4E3B;&#x89D2;&#x6A21;&#x5757;&#x83B7;&#x5F97;&#x7ECF;&#x9A8C;&#xFF0C;&#x91D1;&#x5E01;&#x7B49;&#x5956;&#x52B1;;&#x6D3B;&#x52A8;&#x6A21;&#x5757;&#x5904;&#x7406;&#x5B8C;&#x6210;&#x6D3B;&#x52A8;&#xFF0C;&#x83B7;&#x5F97;&#x5956;&#x52B1;&#x3002;</p>
<p><img src="../imgs/game82.webp" alt=""></p>
<p>&#x56FE;9&#x3001;&#x6740;&#x602A;&#x4E8B;&#x4EF6;&#x5206;&#x53D1;</p>
<p><strong>3.3 &#x5176;&#x4ED6;&#x65B9;&#x9762;&#x7684;&#x4F18;&#x5316;</strong>
<strong>3.3.1 &#x6D88;&#x606F;&#x7EC4;&#x64AD;&#x673A;&#x5236;</strong>
    &#x6D88;&#x606F;&#x7EC4;&#x64AD;&#x7684;&#x4F18;&#x5316;&#xFF0C;&#x5728;&#x8DE8;&#x670D;&#xFF0C;&#x6765;&#x81EA;&#x540C;&#x4E00;&#x670D;&#x7684;&#x5168;&#x90E8;&#x73A9;&#x5BB6;&#x5E7F;&#x64AD;&#x4ECE;&#x5206;&#x522B;&#x5355;&#x72EC;&#x6D88;&#x606F;&#x8F6C;&#x53D1;&#xFF0C;&#x6539;&#x6210;&#x4E00;&#x4E2A;&#x6D88;&#x606F;&#x53D1;&#x56DE;&#x672C;&#x670D;&#xFF0C;&#x7136;&#x540E;&#x518D;&#x5E7F;&#x64AD;&#x7ED9;&#x73A9;&#x5BB6;&#xFF08;&#x6BD4;&#x5982;&#x6765;&#x81EA;&#x540C;&#x4E00;&#x4E2A;&#x670D;n&#x4E2A;&#x73A9;&#x5BB6;&#xFF0C;&#x539F;&#x672C;&#x5E7F;&#x64AD;&#x4E00;&#x6761;&#x6D88;&#x606F;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x4E4B;&#x95F4;&#x8981;&#x5904;&#x7406;n&#x4E2A;RPC&#x6D88;&#x606F;&#xFF0C;&#x73B0;&#x5728;&#x53EA;&#x9700;&#x8981;&#x5904;&#x7406;1&#x4E2A;&#x6D88;&#x606F;,&#x964D;&#x5230;&#x4E86;&#x539F;&#x5148;&#x7684;1/n&#xFF09;</p>
<p><img src="../imgs/game83.jpeg" alt=""></p>
<p>&#x56FE;10&#x3001;&#x6D88;&#x606F;&#x7EC4;&#x64AD;&#x673A;&#x5236; </p>
<p><strong>3.3.2 &#x901A;&#x4FE1;&#x6570;&#x636E;&#x91CF;</strong>
    &#x4E00;&#x4E2A;&#x5B8C;&#x6574;&#x7684;PlayerTemplate&#x6A21;&#x7248;&#x6570;&#x636E;&#x7531;&#x4E8E;&#x5305;&#x542B;&#x4E86;&#x73A9;&#x5BB6;&#x5728;&#x573A;&#x666F;&#x91CC;&#x7528;&#x5230;&#x7684;&#x6240;&#x6709;&#x6570;&#x636E;&#xFF0C;&#x6BD4;&#x5982;&#x89D2;&#x8272;&#x3001;&#x5BA0;&#x7269;&#x3001;&#x5750;&#x9A91;&#x3001;&#x88C5;&#x5907;&#x3001;&#x795E;&#x5668;&#x3001;&#x6CD5;&#x5B9D;&#x3001;&#x65F6;&#x88C5;&#x3001;&#x6280;&#x80FD;&#x3001;&#x7FC5;&#x8180;&#x7B49;&#x7B49;&#xFF0C;&#x6570;&#x636E;&#x91CF;&#x6BD4;&#x8F83;&#x5927;&#xFF0C;&#x5E73;&#x5747;&#x80FD;&#x8FBE;&#x5230;5KB&#x5DE6;&#x53F3;&#xFF0C;&#x9700;&#x8981;&#x5728;&#x670D;&#x52A1;&#x5668;&#x4E4B;&#x95F4;&#x4F20;&#x8F93;&#x65F6;&#x505A;zlib&#x538B;&#x7F29;&#xFF0C;&#x6BD4;&#x5982;&#xFF0C;&#x505A;&#x4E86;&#x538B;&#x7F29;&#x540E;&#xFF0C;11767 Byte&#x7684;&#x73A9;&#x5BB6;&#x6570;&#x636E;&#x80FD;&#x538B;&#x7F29;&#x5230;2337Byte&#xFF0C;&#x538B;&#x7F29;&#x7387;&#x53EF;&#x8FBE;&#x5230;19.86%&#x3002;</p>
<p><strong>3.3.3 &#x5E8F;&#x5217;&#x5316;/&#x53CD;&#x5E8F;&#x5217;&#x5316;</strong>
    &#x6539;&#x9020;&#x524D;&#xFF0C;&#x6240;&#x6709;&#x7684;&#x8BF7;&#x6C42;&#x90FD;&#x9700;&#x8981;&#x5148;&#x5728;&#x672C;&#x670D;&#x505A;AMF3&#x53CD;&#x5E8F;&#x5217;&#x5316;&#xFF0C;&#x5982;&#x679C;&#x8BF7;&#x6C42;&#x662F;&#x9700;&#x8981;&#x8F6C;&#x53D1;&#x5230;&#x8DE8;&#x670D;&#x7684;,&#x518D;&#x901A;&#x8FC7;JSON&#x5E8F;&#x5217;&#x5316;&#x4F20;&#x8F93;&#x7ED9;&#x8DE8;&#x670D;&#xFF0C;&#x5728;&#x8DE8;&#x670D;&#x901A;&#x8FC7;JSON&#x53CD;&#x5E8F;&#x5217;&#x5316;&#xFF0C;&#x6700;&#x7EC8;&#x8BE5;&#x8BF7;&#x6C42;&#x88AB;&#x5904;&#x7406;&#x3002;
    &#x4F46;&#x5B9E;&#x9645;&#x4E0A;&#xFF0C;&#x4E2D;&#x95F4;&#x8FC7;&#x7A0B;JSON&#x5E8F;&#x5217;&#x5316;&#x548C;&#x53CD;&#x5E8F;&#x5217;&#x5316;&#x4F3C;&#x4E4E;&#x662F;&#x6CA1;&#x6709;&#x5FC5;&#x8981;&#x7684;&#xFF0C;&#x7ECF;&#x8FC7;&#x6539;&#x9020;&#xFF0C;&#x5BF9;&#x9700;&#x8981;&#x8F6C;&#x53D1;&#x7ED9;&#x8DE8;&#x670D;&#x7684;&#x8BF7;&#x6C42;&#xFF0C;&#x5728;&#x672C;&#x670D;&#x5148;&#x4E0D;&#x505A;AMF3&#x53CD;&#x5E8F;&#x5217;&#x5316;&#xFF0C;&#x53D1;&#x9001;&#x5230;&#x8DE8;&#x670D;&#x540E;&#x518D;&#x5904;&#x7406;&#xFF0C;&#x8FD9;&#x6837;&#x5C31;&#x5C11;&#x4E86;&#x4E00;&#x6B21;JSON&#x7684;&#x5E8F;&#x5217;&#x5316;&#x548C;&#x53CD;&#x5E8F;&#x5217;&#x5316;&#xFF0C;&#x540C;&#x65F6;&#x6536;&#x76CA;&#x4E86;&#x53E6;&#x5916;&#x7684;&#x4E00;&#x4E2A;&#x597D;&#x5904;:&#x964D;&#x4F4E;&#x4E86;&#x4F20;&#x8F93;&#x7684;&#x5B57;&#x8282;</p>
<p><img src="../imgs/game84.png" alt=""></p>
<p>&#x56FE;12&#x3001;&#x5360;&#x7528;&#x5B57;&#x8282;&#x5BF9;&#x6BD4;</p>
<p><img src="../imgs/game85.webp" alt=""></p>
<p>&#x56FE;11&#x3001;&#x5E8F;&#x5217;&#x5316;&#x548C;&#x53CD;&#x5E8F;&#x5217;&#x5316;</p>
<p><strong>3.3.4 &#x5185;&#x5B58;&#x5360;&#x7528;&#x4F18;&#x5316;</strong>
    Oracle JVM&#x76EE;&#x524D;&#x53EA;&#x80FD;&#x5728;JVM&#x505C;&#x6B62;&#x8FD0;&#x884C;&#x7684;&#x65F6;&#x5019;&#x624D;&#x80FD;&#x505A;&#x5230;&#x91CA;&#x653E;&#x5360;&#x6709;&#x5185;&#x5B58;&#xFF0C;&#x76F4;&#x5230;&#x4E0B;&#x6B21;&#x91CD;&#x542F;&#xFF0C;&#x6240;&#x4EE5;&#x4E3A;&#x4E86;&#x9632;&#x6B62;&#x8D44;&#x6E90;&#x6D6A;&#x8D39;&#xFF0C;&#x5404;&#x79CD;&#x7C7B;&#x578B;&#x7684;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x6E38;&#x620F;&#x670D;&#x52A1;&#x5668;&#x90FD;&#x9700;&#x8981;&#x8BBE;&#x7F6E;&#x4E0D;&#x540C;&#x7684;&#x542F;&#x52A8;&#x53C2;&#x6570;&#x3002;&#x542F;&#x52A8;&#x53C2;&#x6570;&#x7684;&#x8BBE;&#x5B9A;&#x6839;&#x636E;&#x6211;&#x4EEC;&#x81EA;&#x884C;&#x8BBE;&#x7F6E;&#x7684;&#x516C;&#x5F0F;&#xFF0C;&#x5982;&#x4E0B;&#x6240;&#x793A;&#x3002;
    &#x4F46;&#x5185;&#x5B58;&#x5360;&#x7528;&#x4ECD;&#x7136;&#x4F1A;&#x7ECF;&#x5E38;&#x7A81;&#x7834;&#x9884;&#x8B66;&#x7EBF;90%&#xFF0C;&#x7531;&#x4E8E;&#x4E00;&#x65E6;&#x7CFB;&#x7EDF;&#x5206;&#x914D;&#x5185;&#x5B58;&#x53D1;&#x73B0;&#x4E0D;&#x591F;&#x65F6;&#xFF0C;&#x5C31;&#x4F1A;&#x89E6;&#x53D1;&#x81EA;&#x6211;&#x4FDD;&#x62A4;&#x673A;&#x5236;&#xFF0C;&#x8FDB;&#x884C;OOM killer,&#x6240;&#x4EE5;&#x9700;&#x8981;&#x9884;&#x7559;&#x5F88;&#x5927;&#x7684;&#x5185;&#x5B58;&#x7ED9;&#x6BCF;&#x4E2A;JVM&#x8FDB;&#x7A0B;&#xFF0C;&#x800C;&#x4E14;&#x6BCF;&#x6B21;&#x7EF4;&#x62A4;&#x7684;&#x65F6;&#x5019;&#x53BB;&#x811A;&#x672C;&#x4FEE;&#x6539;&#x5185;&#x5B58;&#x4E5F;&#x6BD4;&#x8F83;&#x9EBB;&#x70E6;&#x3002;</p>
<p><img src="../imgs/game86.jpeg" alt=""></p>
<p>&#x200B;    &#x5185;&#x5B58;&#x5360;&#x7528;&#x72B6;&#x51B5;&#x5982;&#x4E0A;&#x56FE;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x66F4;&#x65B0;&#x7EF4;&#x62A4;&#x540E;&#xFF0C;&#x5185;&#x5B58;&#x5360;&#x7528;&#x4E00;&#x8DEF;&#x4E0A;&#x626C;&#xFF0C;&#x4E00;&#x76F4;&#x5230;&#x6700;&#x540E;&#x7EF4;&#x6301;&#x5728;&#x4E00;&#x5B9A;&#x7684;&#x503C;&#xFF0C;&#x4E0D;&#x4F1A;&#x56DE;&#x6536;&#xFF0C;&#x9664;&#x975E;&#x7B49;&#x4E0B;&#x6B21;&#x7EF4;&#x62A4;&#x6216;&#x8005;&#x7CFB;&#x7EDF;&#x89E6;&#x53D1;OOM killer&#x3002; 
&#x200B;    &#x57FA;&#x4E8E;&#x963F;&#x91CC; JVM 1.8&#xFF0C;&#x53EA;&#x8981;&#x5F00;&#x542F;-XX:+DeallocateHeapPages&#xFF0C;CMS&#x80FD;&#x5728;&#x4E0D;&#x91CD;&#x542F;&#x5E94;&#x7528;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#x628A;&#x4E0D;&#x4F7F;&#x7528;&#x7684;HEAP&#x5F52;&#x8FD8;&#x7ED9;&#x7CFB;&#x7EDF;&#x7684;&#x7269;&#x7406;&#x5185;&#x5B58;,&#x8FD9;&#x6837;&#xFF0C;&#x6211;&#x4EEC;&#x5C31;&#x4E0D;&#x9700;&#x8981;&#x9884;&#x7559;&#x5F88;&#x591A;&#x7A7A;&#x95F4;&#x7ED9;JVM&#xFF0C;&#x518D;&#x4E5F;&#x4E0D;&#x7528;&#x62C5;&#x5FC3;&#x88AB;&#x8BEF;&#x6740;&#x4E86;&#x3002;
&#x200B;    &#x62FF;&#x6211;&#x4EEC;&#x4E00;&#x6B3E;&#x5185;&#x6D4B;&#x9636;&#x6BB5;&#x7684;&#x6E38;&#x620F;&#x4E3E;&#x4F8B;&#xFF0C;&#x4F7F;&#x7528;&#x4E86;ALI JVM&#x540E;&#xFF0C; 64&#x5185;&#x5B58;&#x914D;&#x7F6E;&#x7684;&#x673A;&#x5668;&#x6700;&#x540E;&#x5F00;&#x5230;&#x4E86;24&#x4E2A;&#x65B0;&#x533A;&#xFF0C;&#x76F8;&#x6BD4;&#x8D77;&#x4EE5;&#x524D;64G&#x5185;&#x5B58;&#x7684;&#x673A;&#x5668;&#xFF0C;&#x5355;&#x53F0;&#x53EA;&#x80FD;&#x653E;9&#x4E2A;&#x72EC;&#x7ACB;&#x7684;&#x6E38;&#x620F;&#x533A;&#x7684;&#x72B6;&#x51B5;&#x4E0B;&#xFF0C;&#x5355;&#x533A;&#x7684;&#x6210;&#x672C;&#x5C06;&#x4F1A;&#x8282;&#x7701;62.5% &#x673A;&#x5668;&#x8D44;&#x6E90;&#xFF0C;&#x975E;&#x5E38;&#x53EF;&#x89C2;&#x3002;&#x5B8C;&#x7F8E;&#x7684;&#x89E3;&#x51B3;&#x4E86;&#x5185;&#x5B58;&#x7ECF;&#x5E38;&#x5403;&#x7D27;&#x7684;&#x95EE;&#x9898;&#xFF0C;&#x5E76;&#x5927;&#x5E45;&#x8282;&#x7701;&#x4E86;&#x6210;&#x672C;&#x3002;</p>
<p><img src="../imgs/game87.png" alt=""></p>
<p>&#x200B;    &#x4E0A;&#x56FE;&#x5C31;&#x662F;&#x4F7F;&#x7528;&#x4E86;Ali JDK&#x540E;&#x7684;&#x952F;&#x9F7F;&#x5F62;&#x6548;&#x679C;&#xFF0C;&#x6BCF;&#x9694;&#x4E00;&#x5B9A;&#x65F6;&#x95F4;&#x95F2;&#x7F6E;&#x5185;&#x5B58;&#x4F1A;&#x88AB;&#x7CFB;&#x7EDF;&#x56DE;&#x6536;&#xFF0C;&#x8FD9;&#x5728;Oracle JVM&#x662F;&#x96BE;&#x4EE5;&#x505A;&#x5230;&#x7684;&#x3002;</p>
<p><strong>3.3.5 &#x670D;&#x52A1;&#x5668;&#x5206;&#x7EC4;&#x673A;&#x5236;</strong>
    &#x4E0D;&#x5B9A;&#x5411;&#x8DE8;&#x670D;&#x662F;&#x6307;&#x4EFB;&#x610F;&#x6E38;&#x620F;&#x533A;&#x7684;&#x73A9;&#x5BB6;&#x90FD;&#x6709;&#x53EF;&#x80FD;&#x5339;&#x914D;&#x5230;&#x4E00;&#x8D77;&#x8FDB;&#x884C;&#x6E38;&#x620F;&#x73A9;&#x6CD5;&#x7684;&#x4F53;&#x9A8C;&#xFF0C;&#x6BD4;&#x5982;&#x8DE8;&#x670D;&#x6218;&#x573A;&#xFF0C;&#x6BD4;&#x5982;&#x8DE8;&#x670D;&#x526F;&#x672C;&#x5339;&#x914D;&#xFF0C;&#x5982;&#x53F3;&#x56FE;&#x6240;&#x793A;:</p>
<p><img src="../imgs/game88.webp" alt=""></p>
<p>&#x56FE;15&#x3001;&#x670D;&#x52A1;&#x5668;&#x672A;&#x5206;&#x7EC4;&#x524D;</p>
<p>&#x200B;    &#x5982;&#x4F55;&#x5728;&#x6E38;&#x620F;&#x6B63;&#x5F0F;&#x5927;&#x533A;&#x4E2D;&#x9009;&#x62E9;&#x51E0;&#x4E2A;&#x670D;&#x505A;&#x7070;&#x5EA6;&#x670D;&#xFF0C;&#x53C8;&#x4E0D;&#x5F71;&#x54CD;&#x4E0D;&#x5B9A;&#x5411;&#x8DE8;&#x670D;&#x4F53;&#x9A8C;;&#x4EE5;&#x53CA;&#x5982;&#x4F55;&#x89E3;&#x51B3;&#x65B0;&#x8001;&#x670D;&#x73A9;&#x5BB6;&#x6218;&#x529B;&#x53D1;&#x5C55;&#x4E0D;&#x5728;&#x540C;&#x4E00;&#x8D77;&#x8DD1;&#x7EBF;&#x800C;&#x5BFC;&#x81F4;&#x7684;&#x4E0D;&#x5E73;&#x8861;&#x95EE;&#x9898;&#x66FE;&#x4E00;&#x5EA6;&#x8BA9;&#x4EBA;&#x7EA0;&#x7ED3;&#x3002;</p>
<p><img src="../imgs/game89.jpeg" alt=""></p>
<p>&#x56FE;16&#x3001;&#x670D;&#x52A1;&#x5668;&#x5206;&#x7EC4;&#x540E;</p>
<p>&#x6BD4;&#x5982;&#x6E38;&#x620F;&#x4EA7;&#x54C1;&#x63A8;&#x51FA;&#x4E86;&#x5927;&#x578B;&#x8D44;&#x6599;&#x7247;&#xFF0C;&#x60F3;&#x5148;&#x505A;&#x4E0B;&#x7070;&#x5EA6;&#x6D4B;&#x8BD5;&#xFF0C;&#x8BA9;1~4&#x533A;&#x7684;&#x73A9;&#x5BB6;&#x5148;&#x505A;&#x4E0B;&#x65B0;&#x529F;&#x80FD;&#x7684;&#x4F53;&#x9A8C;&#xFF0C;&#x540C;&#x65F6;&#x53C8;&#x80FD;&#x9632;&#x6B62;&#x73A9;&#x5BB6;&#x7A7F;&#x4E86;&#x4E00;&#x4EF6;&#x65E7;&#x7248;&#x672C;&#x4E0D;&#x5B58;&#x5728;&#x7684;&#x88C5;&#x5907;&#x800C;&#x5728;&#x8DE8;&#x670D;&#x73AF;&#x5883;&#x4E0B;&#x62A5;&#x5F02;&#x5E38;&#xFF0C;&#x6839;&#x636E;&#x8FD0;&#x8425;&#x9700;&#x6C42;&#x901A;&#x8FC7;&#x5206;&#x7EC4;&#xFF0C;&#x5C31;&#x5F88;&#x5B8C;&#x7F8E;&#x7684;&#x89E3;&#x51B3;&#x4E86;&#x4E0A;&#x8FF0;&#x95EE;&#x9898;&#x3002;</p>
<p><strong>3.3.6 &#x6218;&#x533A;&#x81EA;&#x52A8;&#x5206;&#x914D;&#x673A;&#x5236;*</strong></p>
<p><img src="../imgs/game90.png" alt=""></p>
<p>&#x56FE;17&#x3001;&#x6218;&#x533A;&#x81EA;&#x52A8;&#x5206;&#x914D;</p>
<p>&#x200B;    &#x8C03;&#x6574;&#x540E;&#xFF0C;&#x6BCF;&#x4E00;&#x79CD;&#x57FA;&#x4E8E;&#x6218;&#x533A;&#x7684;&#x8DE8;&#x670D;&#x7C7B;&#x578B;&#x90FD;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x8C03;&#x6574;&#x65F6;&#x95F4;&#x95F4;&#x9694;&#xFF0C;&#x5230;&#x65F6;&#x95F4;&#x70B9;&#x5168;&#x5C40;&#x670D;&#x52A1;&#x5668;&#xFF08;global server&#xFF09;&#x7CFB;&#x7EDF;&#x81EA;&#x52A8;&#x6839;&#x636E;&#x5168;&#x533A;&#x7684;&#x6D3B;&#x8DC3;&#x6218;&#x529B;&#x5339;&#x914D;&#x8FDB;&#x884C;&#x8C03;&#x6574;&#xFF0C;&#x8BA9;&#x8FD0;&#x8425;&#x4EBA;&#x5458;&#x4ECE;&#x7E41;&#x6742;&#x7684;&#x914D;&#x7F6E;&#x4E2D;&#x89E3;&#x8131;&#x51FA;&#x6765;&#x3002;&#x5B9A;&#x5411;&#x8DE8;&#x670D;&#x662F;&#x6307;&#x5728;&#x4E00;&#x5B9A;&#x65F6;&#x95F4;&#x5185;&#x4F1A;&#x56FA;&#x5B9A;&#x53C2;&#x4E0E;&#x8DE8;&#x670D;&#x73A9;&#x6CD5;&#x7684;&#x51E0;&#x4E2A;&#x56FD;&#x5BB6;&#xFF0C;&#x5E38;&#x7528;&#x4E8E;&#x6218;&#x533A;&#x4E2D;&#x56FD;&#x5BB6;&#x4E4B;&#x95F4;&#x5BF9;&#x6218;&#xFF0C;&#x5982;&#x53F3;&#x56FE;&#x6240;&#x793A;&#xFF0C;&#x9700;&#x8981;&#x8FD0;&#x8425;&#x5728;&#x540E;&#x53F0;&#x914D;&#x7F6E;;&#x5F53;&#x4E00;&#x6BB5;&#x65F6;&#x95F4;&#x540E;&#xFF0C;&#x968F;&#x7740;&#x73A9;&#x5BB6;&#x6D41;&#x5931;&#xFF0C;&#x53C8;&#x9700;&#x8981;&#x8FD0;&#x8425;&#x6839;&#x636E;&#x6218;&#x529B;&#x8FDB;&#x884C;&#x6218;&#x533A;&#x7684;&#x8C03;&#x6574;&#xFF0C;&#x5BF9;&#x8FD0;&#x8425;&#x4EBA;&#x5458;&#x7684;&#x8981;&#x6C42;&#x6BD4;&#x8F83;&#x9AD8;</p>
<p><strong>3.3.7 &#x8DE8;&#x670D;&#x65AD;&#x7EBF;&#x91CD;&#x8FDE;&#x673A;&#x5236;</strong>
    &#x6BD4;&#x5982;&#x6218;&#x573A;&#x7CFB;&#x7EDF;&#x6216;&#x7EC4;&#x961F;&#x526F;&#x672C;&#xFF0C;&#x7531;&#x4E8E;&#x7F51;&#x7EDC;&#x72B6;&#x51B5;&#x800C;&#x6389;&#x7EBF;&#xFF0C;&#x5982;&#x679C;&#x91CD;&#x65B0;&#x767B;&#x5F55;&#x540E;&#xFF0C;&#x6CA1;&#x6CD5;&#x8FDB;&#x5165;&#xFF0C;&#x5C06;&#x4F1A;&#x4E25;&#x91CD;&#x5F71;&#x54CD;&#x6218;&#x573A;&#x7684;&#x6218;&#x51B5;&#xFF0C;&#x987A;&#x98CE;&#x5C40;&#x9A6C;&#x4E0A;&#x5C31;&#x53EF;&#x80FD;&#x4F1A;&#x53D8;&#x6210;&#x9006;&#x98CE;&#x5C40;&#xFF0C;&#x4E3B;&#x529B;DPS&#x6389;&#x7EBF;&#x526F;&#x672C;&#x5C31;&#x6709;&#x53EF;&#x80FD;&#x901A;&#x4E0D;&#x4E86;&#xFF0C;&#x8FD9;&#x4E2A;&#x673A;&#x5236;&#x5C31;&#x5F25;&#x8865;&#x4E86;&#x8FD9;&#x5757;&#x7684;&#x7F3A;&#x9677;&#x3002;</p>
<h3 id="4&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;"><a name="4&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#4&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>4.&#x652F;&#x6301;&#x7684;&#x73A9;&#x6CD5;</h3>
<p>&#x200B;    &#x76EE;&#x524D;&#xFF0C;&#x6211;&#x4EEC;&#x5DF2;&#x7ECF;&#x80FD;&#x652F;&#x6301;&#x4EFB;&#x610F;&#x7684;&#x6E38;&#x620F;&#x533A;&#x73A9;&#x5BB6;&#x53EF;&#x4EE5;&#x5230;&#x4EFB;&#x610F;&#x7684;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x884C;&#x6E38;&#x620F;&#x529F;&#x80FD;&#x7684;&#x4F53;&#x9A8C;&#x3002;&#x6BD4;&#x5982;&#x5DF2;&#x7ECF;&#x5B9E;&#x73B0;&#x7684;&#x8DE8;&#x670D;&#x7EC4;&#x961F;&#x526F;&#x672C;&#x3001;&#x8DE8;&#x670D;&#x6218;&#x573A;&#x3001;&#x8DE8;&#x670D;&#x56FD;&#x6218;&#x3001;&#x8DE8;&#x670D;&#x7687;&#x57CE;&#x4E89;&#x593A;&#x3001;&#x8DE8;&#x670D;&#x8D44;&#x6E90;&#x6218;&#x3001;&#x866B;&#x7FA4;&#x5165;&#x4FB5;&#x6218;&#x3001;&#x8DE8;&#x670D;&#x62BC;&#x9556;&#x3001;&#x6316;&#x77FF;&#x4E89;&#x593A;&#x7B49;&#x3002;
&#x200B;    &#x4E5F;&#x652F;&#x6301;&#x73A9;&#x5BB6;&#x5728;&#x672C;&#x670D;&#x5C31;&#x53EF;&#x4EE5;&#x8FDB;&#x884C;&#x8DE8;&#x670D;&#x4E92;&#x52A8;&#xFF0C;&#x6BD4;&#x5982;&#x548C;&#x522B;&#x7684;&#x533A;&#x7684;&#x73A9;&#x5BB6;&#x804A;&#x5929;&#x3001;&#x52A0;&#x597D;&#x53CB;&#x3001;&#x9001;&#x793C;&#x7B49;&#x65E0;&#x7F1D;&#x4EA4;&#x4E92;&#xFF0C;&#x53CA;&#x56FD;&#x5BB6;&#x62CD;&#x5356;&#x884C;&#xFF0C;&#x4E16;&#x754C;&#x62CD;&#x5356;&#x884C;&#x7684;&#x8DE8;&#x670D;&#x8D38;&#x6613;&#x3002;
&#x200B;    &#x751A;&#x81F3;&#x652F;&#x6301;&#x73A9;&#x5BB6;&#x7A7F;&#x8D8A;&#x5230;&#x53E6;&#x5916;&#x7684;&#x6E38;&#x620F;&#x533A;&#x505A;&#x4EFB;&#x610F;&#x7684;&#x6E38;&#x620F;&#x4F53;&#x9A8C;&#xFF0C;&#x6BD4;&#x5982;&#x4E00;&#x533A;&#x7684;&#x73A9;&#x5BB6;&#x542C;&#x8BF4;&#x4E8C;&#x533A;&#x670D;&#x5728;&#x4E3E;&#x884C;&#x62A2;&#x4EB2;&#x6D3B;&#x52A8;&#xFF0C;
&#x200B;    &#x4F60;&#x53EF;&#x4EE5;&#x8DD1;&#x5230;2&#x533A;&#x53BB;&#x89C2;&#x8D4F;&#x53C2;&#x4E0E;&#xFF0C;&#x4E5F;&#x8DD1;&#x5230;&#x4EFB;&#x610F;&#x7684;&#x533A;&#x7684;&#x4E2D;&#x592E;&#x5E7F;&#x573A;&#x53BB;&#x663E;&#x6446;&#x4F60;&#x7684;&#x6781;&#x54C1;&#x5957;&#x88C5;&#x3002;</p>
<h3 id="5&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;"><a name="5&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;" class="anchor-navigation-ex-anchor" href="#5&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;"><i class="fa fa-link" aria-hidden="true"></i></a>5.&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x6570;&#x636E;</h3>
<p>&#x200B;    &#x5982;&#x56FE;18&#xFF0C;&#x8DE8;&#x670D;&#x5B9A;&#x5411;&#x73A9;&#x6CD5;&#x6709;&#x6218;&#x533A;&#x56FD;&#x5BB6;&#x73A9;&#x6CD5;&#xFF0C;&#x866B;&#x7FA4;&#x5165;&#x4FB5;&#xFF0C;&#x8DE8;&#x670D;&#x62BC;&#x9556;&#xFF0C;&#x6316;&#x77FF;&#x4E89;&#x593A;, &#x8DE8;&#x670D;&#x7687;&#x57CE;&#x4E89;&#x593A;&#xFF0C;&#x8DE8;&#x670D;&#x56FD;&#x6218;&#x7B49;&#xFF0C;&#x5982;&#x4E0B;&#x56FE;&#x6240;&#x793A;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x770B;&#x51FA;&#x8FD9;&#x79CD;&#x73A9;&#x6CD5;&#x7684;&#x89C4;&#x5F8B;:&#x6BCF;&#x6B21;&#x6D3B;&#x52A8;&#x5F00;&#x542F;&#xFF0C;&#x8DE8;&#x670D;&#x5C31;&#x4F1A;&#x8FCE;&#x6765;&#x4E00;&#x6CE2;&#x6CE2;&#x73A9;&#x5BB6;&#x6D8C;&#x5165;&#xFF0C;&#x6D3B;&#x52A8;&#x4E00;&#x7ED3;&#x675F;&#xFF0C;&#x73A9;&#x5BB6;&#x5C31;&#x4F1A;&#x79BB;&#x5F00;&#xFF0C;4&#x4E2A;&#x8DE8;&#x670D;&#x8FDB;&#x7A0B;&#x652F;&#x6301;&#x4E86;7600&#x5728;&#x7EBF;&#x7684;&#x73A9;&#x5BB6;&#x3002;</p>
<p><img src="../imgs/game91.png" alt=""></p>
<p>&#x56FE;18&#x3001;&#x5B9A;&#x5411;&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x56FE;</p>
<p>&#x200B;    &#x5982;&#x56FE;19&#xFF0C;&#x8DE8;&#x670D;&#x975E;&#x5B9A;&#x5411;&#x6027;&#x73A9;&#x6CD5;&#x6709;&#x8DE8;&#x670D;&#x7EC4;&#x961F;&#x526F;&#x672C;&#xFF0C;&#x8DE8;&#x670D;&#x6218;&#x573A;&#x7B49;&#xFF0C;&#x652F;&#x6301;&#x8D1F;&#x8F7D;&#x5747;&#x8861;&#xFF0C;&#x53EF;&#x4EE5;&#x968F;&#x65F6;&#x52A8;&#x6001;&#x589E;&#x52A0;&#x8DE8;&#x670D;&#x3002;&#x5982;&#x53F3;&#x56FE;&#x6240;&#x793A;&#xFF0C;&#x8FD9;&#x4E9B;&#x73A9;&#x6CD5;&#x7684;&#x89C4;&#x5F8B;&#x662F;24&#x5C0F;&#x65F6;&#x968F;&#x65F6;&#x53EF;&#x4EE5;&#x4F53;&#x9A8C;&#x8FDB;&#x5165;&#xFF0C;&#x5728;&#x7EBF;&#x6BD4;&#x8F83;&#x7A33;&#x5B9A;&#xFF0C;8&#x4E2A;&#x8DE8;&#x670D;&#x8FDB;&#x7A0B;&#x652F;&#x6301;&#x4E86;28000&#x5728;&#x7EBF;&#x7684;&#x73A9;&#x5BB6;&#x3002;</p>
<p> <img src="../imgs/game92.webp" alt=""></p>
<p> &#x56FE;19&#x3001;&#x4E0D;&#x5B9A;&#x5411;&#x8DE8;&#x670D;&#x5728;&#x7EBF;&#x56FE; </p>
<p>&#x200B;    &#x56FE;20&#x662F;&#x6E38;&#x620F;&#x67D0;&#x4E2A;&#x8DE8;&#x670D;&#x73A9;&#x6CD5;&#x7684;&#x622A;&#x56FE;&#xFF0C;&#x53EF;&#x4EE5;&#x770B;&#x51FA;&#xFF0C;&#x8BE5;&#x6E38;&#x620F;&#x5F53;&#x65F6;&#x5177;&#x6709;&#x5F88;&#x9AD8;&#x7684;&#x4EBA;&#x6C14;&#x3002;&#x5F53;&#x65F6;&#x7684;&#x6700;&#x9AD8;DAU&#x4E3A;650467&#xFF0C;&#x6700;&#x9AD8;PCU&#x4E3A;143319</p>
<p><img src="../imgs/game93.webp" alt=""></p>
<p>&#x56FE;20&#x3001;&#x8DE8;&#x670D;&#x73A9;&#x6CD5;&#x5728;&#x7EBF;&#x622A;&#x56FE;</p>
<p>&#x200B;    &#x56FE;21&#x4E3A;&#x8DE8;&#x670D;&#x901A;&#x4FE1;&#x62D3;&#x6251;&#x56FE;&#xFF0C;&#x5C5E;&#x4E8E;&#x6574;&#x4F53;&#x67B6;&#x6784;&#x7684;&#x6838;&#x5FC3;&#x90E8;&#x5206;&#xFF0C;&#x5173;&#x4E8E;&#x8FD9;&#x4E00;&#x90E8;&#x5206;&#x7684;&#x8BF4;&#x660E;&#x89C1;&#x56FE;&#x8868;:6 &#x6280;&#x672F;&#x67B6;&#x6784;</p>
<p><img src="../imgs/game94.jpeg" alt=""></p>
<p>&#x56FE;21&#x3001;&#x6E38;&#x620F;&#x670D;&amp;&#x8DE8;&#x670D;&#x901A;&#x4FE1;&#x62D3;&#x6251;&#x56FE;</p>
<table>
<thead>
<tr>
<th>&#x670D;&#x52A1;&#x5668;&#x79CD;&#x7C7B;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>&#x6E38;&#x620F;&#x903B;&#x8F91;&#x670D;&#x52A1;&#x5668; Game Server</td>
<td>1.&#x7F51;&#x5173;&#xFF0C;&#x8DDF;&#x73A9;&#x5BB6;&#x4FDD;&#x6301;&#x8FDE;&#x63A5;&#xFF0C; &#x63D0;&#x4F9B;&#x5BF9;&#x5916;&#x8BBF;&#x95EE;,&#x8F6C;&#x53D1;&#x6D88;&#x606F;&#xFF0C;&#x76F4;&#x63A5;&#x4E0E;&#x5BA2;&#x6237;&#x6D88;&#x606F;&#x4EA4;&#x4E92;&#xFF1B; 2.&#x534F;&#x8BAE;&#x7684;&#x52A0;&#x5BC6;&#x89E3;&#x5BC6;,&#x538B;&#x7F29;&#x89E3;&#x538B;&#x7F29; 3.&#x6E38;&#x620F;&#x903B;&#x8F91;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x6838;&#x5FC3;&#x903B;&#x8F91;&#x7684;&#x5B9E;&#x73B0;&#x90FD;&#x5728;&#x8FD9;&#x91CC;; 4. Game &#x4F1A;&#x7F13;&#x5B58;&#x73A9;&#x5BB6;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5B9A;&#x65F6;&#x6301;&#x4E45;&#x5316;&#x66F4;&#x65B0;&#x7684;&#x6570;&#x636E;&#x5230;&#x6570;&#x636E;&#x5E93;&#xFF0C;&#x800C;&#x5BF9;&#x4E8E;&#x975E;&#x5728;&#x7EBF;&#x73A9;&#x5BB6;&#xFF0C;&#x7528;LRU&#x7B97;&#x6CD5;&#xFF1B; 5.&#x4E0D;&#x540C;Game server&#x95F4;&#x53EF;&#x4EE5;&#x8DE8;&#x533A;&#x901A;&#x4FE1;&#xFF0C;&#x8DE8;&#x533A;&#x52A0;&#x597D;&#x53CB;&#xFF0C;&#x804A;&#x5929;&#x7B49; 6.&#x548C;&#x5168;&#x5C40;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x884C;RPC &#x901A;&#x4FE1;&#xFF0C;&#x8FDB;&#x884C;&#x9012;&#x4EA4;&#x7533;&#x8BF7;&#x5339;&#x914D;&#x7B49;&#x8BF7;&#x6C42; 7.&#x548C;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x884C;RPC &#x901A;&#x4FE1;&#xFF0C;&#x627F;&#x62C5;&#x8DE8;&#x670D;&#x540E;&#x7684;&#x6307;&#x4EE4;&#x8F6C;&#x53D1;</td>
</tr>
<tr>
<td>&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;Cross  Server</td>
<td>&#x5904;&#x7406;&#x8DE8;&#x670D;&#x76F8;&#x5173;&#x7684;&#x903B;&#x8F91;&#xFF0C;&#x4EFB;&#x610F;&#x533A;&#x7684;&#x73A9;&#x5BB6;&#x53EF;&#x4EE5;&#x5230;&#x8FBE;&#x5230;&#x4EFB;&#x610F;&#x7684;&#x7684;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;, &#x6839;&#x636E;&#x8D1F;&#x8F7D;&#x538B;&#x529B;&#x65E0;&#x9650;&#x52A8;&#x6001;&#x6269;&#x5C55;</td>
</tr>
<tr>
<td>&#x5168;&#x5C40;&#x670D;&#x52A1;&#x5668; Gobal Server</td>
<td>&#x63A7;&#x5236;&#x8DE8;&#x670D;&#x670D;&#x52A1;&#x5668;&#x7684;&#x8D1F;&#x8F7D;&#x5747;&#x8861;&#xFF0C;&#x5904;&#x7406;&#x8981;&#x8DE8;&#x670D;&#x7684;&#x73A9;&#x5BB6;&#x7684;&#x5339;&#x914D;&#x5904;&#x7406;&#xFF0C;&#x5206;&#x914D;&#x8DE8;&#x670D;&#x623F;&#x95F4;&#x7B49;</td>
</tr>
<tr>
<td>Redis</td>
<td>&#x505A;&#x6218;&#x533A;&#x7684;Pub/Sub&#x670D;&#x52A1;</td>
</tr>
</tbody>
</table>
<p>&#x5173;&#x4E8E;&#x6574;&#x4F53;&#x67B6;&#x6784;&#x7684;&#x4ECB;&#x7ECD;&#xFF0C;&#x540E;&#x7EED;&#x7684;&#x6587;&#x7AE0;&#x4F1A;&#x548C;&#x5927;&#x5BB6;&#x5206;&#x4EAB;&#x3002;</p>
<h3 id="6&#x5C0F;&#x7ED3;"><a name="6&#x5C0F;&#x7ED3;" class="anchor-navigation-ex-anchor" href="#6&#x5C0F;&#x7ED3;"><i class="fa fa-link" aria-hidden="true"></i></a>6.&#x5C0F;&#x7ED3;</h3>
<p>&#x6B64;&#x5957;&#x67B6;&#x6784;&#x5386;&#x7ECF;&#x4E86;&#x300A;&#x5927;&#x95F9;&#x5929;&#x5BAB;OL&#x300B;&#x3001;&#x300A;&#x8BF8;&#x795E;&#x9EC4;&#x660F;&#x300B;&#x3001;&#x300A;&#x66B4;&#x98CE;&#x738B;&#x5EA7;&#x300B;&#x3001;&#x300A;&#x60CA;&#x5929;&#x52A8;&#x5730;&#x300B;&#xFF0C;&#x300A;&#x4E09;&#x6253;&#x767D;&#x9AA8;&#x7CBE;&#x300B;&#x3001;&#x300A;&#x82F1;&#x96C4;&#x9886;&#x4E3B;&#x300B;&#x3001;&#x300A;&#x5C01;&#x795E;&#x9738;&#x4E1A;&#x300B;&#x7B49;&#x5148;&#x540E;&#x8FD1;&#x4E24;&#x4E07;&#x7EC4;&#x670D;&#x52A1;&#x5668;&#x8FD0;&#x884C;&#x7684;&#x9A8C;&#x8BC1;&#x548C;&#x56E2;&#x961F;&#x7684;&#x6280;&#x672F;&#x79EF;&#x7D2F;&#x3002;</p>
<p>&#x56FE;22&#x3001;&#x6211;&#x4EEC;&#x7684;&#x6E38;&#x620F;&#x4EA7;&#x54C1;</p>
<p><img src="../imgs/game95.webp" alt=""></p>
<p>&#x200B;    &#x672C;&#x6587;&#x4ECE;&#x5F53;&#x524D;&#x6E38;&#x620F;&#x5E02;&#x573A;&#x53D1;&#x5C55;&#x7684;&#x80CC;&#x666F;&#x51FA;&#x53D1;&#xFF0C;&#x63D0;&#x51FA;&#x4E86;&#x8BBE;&#x8BA1;&#x81EA;&#x7531;&#x4EA4;&#x4E92;&#x7684;&#x201C;&#x8DE8;&#x57DF;&#x4F53;&#x7CFB;&#x201D;&#x7684;&#x5FC5;&#x8981;&#x6027;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x5B9E;&#x73B0;&#x8DE8;&#x670D;&#x67B6;&#x6784;&#x8FC7;&#x7A0B;&#x4E2D;&#x5BF9;&#x8BBE;&#x8BA1;&#x76EE;&#x6807;&#x3001;&#x539F;&#x5219;&#x3001;&#x5B58;&#x5728;&#x7684;&#x6280;&#x672F;&#x96BE;&#x70B9;&#x8FDB;&#x884C;&#x4E86;&#x601D;&#x8003;&#xFF0C;&#x5B9E;&#x73B0;&#x4E86;&#x4E00;&#x5957;&#x7528;&#x4E8E;&#x8DE8;&#x670D;&#x901A;&#x4FE1;&#x7684;&#x9AD8;&#x541E;&#x5410;&#x7684;RPC&#x901A;&#x4FE1;&#x6846;&#x67B6;&#xFF0C;&#x5148;&#x540E;&#x4F53;&#x9A8C;&#x4E86;&#x88AB;&#x52A8;&#x62C9;&#x53D6;&#x6A21;&#x5F0F;&#x5E26;&#x6765;&#x7684;&#x5751;&#xFF0C;&#x548C;&#x6539;&#x6210;&#x4E3B;&#x52A8;&#x63A8;&#x9001;&#x6A21;&#x5F0F;&#x5E26;&#x6765;&#x7684;&#x4FBF;&#x5229;&#x3002;&#x5E76;&#x4E14;&#xFF0C;&#x5BF9;&#x8BE5;&#x67B6;&#x6784;&#x8BBE;&#x8BA1;&#x5728;&#x6D88;&#x606F;&#x7EC4;&#x64AD;&#xFF0C;&#x901A;&#x4FE1;&#x91CF;&#xFF0C;&#x6D88;&#x606F;&#x5E8F;&#x5217;&#x5316;/&#x53CD;&#x5E8F;&#x5217;&#x5316;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x5206;&#x7EC4;&#xFF0C;&#x6218;&#x533A;&#x81EA;&#x52A8;&#x5206;&#x914D;&#xFF0C;&#x65AD;&#x7EBF;&#x91CD;&#x8FDE;&#x7B49;&#x8FDB;&#x884C;&#x4E86;&#x591A;&#x65B9;&#x9762;&#x673A;&#x5236;&#x7684;&#x5206;&#x6790;&#x53CA;&#x6DF1;&#x5EA6;&#x4F18;&#x5316;&#xFF0C;&#x6700;&#x540E;&#x4E0A;&#x7EBF;&#x5B9E;&#x8DF5;&#x505A;&#x4E86;&#x53EF;&#x884C;&#x6027;&#x9A8C;&#x8BC1;&#xFF0C;&#x63D0;&#x4F9B;&#x4E86;&#x5F3A;&#x6709;&#x529B;&#x7684;&#x6570;&#x636E;&#x652F;&#x6301;&#xFF0C;&#x603B;&#x4F53;&#x8868;&#x73B0;&#x7A33;&#x5B9A;&#x6D41;&#x7545;&#x3002; </p>
<footer class="page-footer"><span class="copyright">&#x5982;&#x9700;&#x4E0B;&#x8F7D;&#x672C;&#x7AD9;&#x5168;&#x90E8;&#x6280;&#x672F;&#x6587;&#x7AE0;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x3010;&#x9AD8;&#x6027;&#x80FD;&#x670D;&#x52A1;&#x5668;&#x5F00;&#x53D1;&#x3011;&#x516C;&#x4F17;&#x53F7;&#x56DE;&#x590D;&#x5173;&#x952E;&#x5B57;&#x201C;&#x6587;&#x7AE0;&#x4E0B;&#x8F7D;&#x201D;&#x5373;&#x53EF;&#x3002;</span><span class="footer-modification">&#x6700;&#x8FD1;&#x66F4;&#x65B0;&#x65F6;&#x95F4;&#xFF1A;
2020-10-08 00:03:27
</span></footer>
<script>console.log("plugin-popup....");document.onclick = function(e){ e.target.tagName === "IMG" && window.open(e.target.src,e.target.src)}</script><style>img{cursor:pointer}</style>
						
					</section>
					
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

				</div>
			</div>
			
		</div>

		
		
		<a href="12经典游戏服务器端架构概述.html" class="navigation navigation-prev " aria-label="Previous page: 12 经典游戏服务器端架构概述">
			<i class="fa fa-angle-left"></i>
		</a>
		
		
		<a href="../程序员面试题精讲/" class="navigation navigation-next " aria-label="Next page: 程序员面试题精讲">
			<i class="fa fa-angle-right"></i>
		</a>
		
		
		
	</div>
	<script>
		var gitbook = gitbook || [];
		gitbook.push(function() {
			gitbook.page.hasChanged({"page":{"title":"13 游戏跨服架构进化之路","level":"9.1.13","depth":2,"next":{"title":"程序员面试题精讲","level":"10.1","depth":1,"path":"articles/程序员面试题精讲/README.md","ref":"articles/程序员面试题精讲/README.md","articles":[{"title":"腾讯后台开发实习生技能要求","level":"10.1.1","depth":2,"path":"articles/程序员面试题精讲/腾讯后台开发实习生技能要求.md","ref":"articles/程序员面试题精讲/腾讯后台开发实习生技能要求.md","articles":[]},{"title":"聊聊如何拿大厂的 offer","level":"10.1.2","depth":2,"path":"articles/程序员面试题精讲/聊聊如何拿大厂的offer.md","ref":"articles/程序员面试题精讲/聊聊如何拿大厂的offer.md","articles":[]},{"title":"网络通信题目集锦","level":"10.1.3","depth":2,"path":"articles/程序员面试题精讲/网络通信题目集锦.md","ref":"articles/程序员面试题精讲/网络通信题目集锦.md","articles":[]},{"title":"我面试后端开发经理的经历","level":"10.1.4","depth":2,"path":"articles/程序员面试题精讲/我面试后端开发经理的经历.md","ref":"articles/程序员面试题精讲/我面试后端开发经理的经历.md","articles":[]},{"title":"Linux C/C++后端开发面试问哪些问题","level":"10.1.5","depth":2,"path":"articles/程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.md","ref":"articles/程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.md","articles":[]}]},"previous":{"title":"12 经典游戏服务器端架构概述","level":"9.1.12","depth":2,"path":"articles/游戏开发专题/12经典游戏服务器端架构概述.md","ref":"articles/游戏开发专题/12经典游戏服务器端架构概述.md","articles":[]},"dir":"ltr"},"config":{"plugins":["chapter-fold","-lunr","-search","search-pro","splitter","popup","back-to-top-button","hide-element","prism","-highlight","tbfed-pagefooter","code","anchor-navigation-ex","theme-fexa","livereload"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"tbfed-pagefooter":{"copyright":"如需下载本站全部技术文章，可以在【高性能服务器开发】公众号回复关键字“文章下载”即可。","modify_label":"最近更新时间：","modify_format":"YYYY-MM-DD HH:mm:ss"},"chapter-fold":{},"prism":{},"livereload":{},"splitter":{},"search-pro":{},"popup":{},"theme-fexa":{"search-placeholder":"输入关键字搜索","logo":"./logo.png","favicon":"./favicon.ico"},"code":{"copyButtons":true},"hide-element":{"elements":[".gitbook-link"]},"fontsettings":{"theme":"white","family":"sans","size":2},"anchor-navigation-ex":{"showLevel":false,"associatedWithSummary":true,"mode":"float","showGoTop":false,"printLog":false,"multipleH1":true,"float":{"floatIcon":"fa fa-navicon","showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""},"pageTop":{"showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""}},"back-to-top-button":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","author":"easy_coder","pdf":{"pageBreaksBefore":"/","headerTemplate":null,"paperSize":"a4","margin":{"right":62,"left":62,"top":36,"bottom":36},"fontSize":12,"fontFamily":"Arial","footerTemplate":null,"chapterMark":"pagebreak","pageNumbers":false},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"isbn":"","variables":{},"title":"高性能服务器开发 技术专栏","links":{},"gitbook":"*","description":"","theme-default":{"showLevel":true},"extension":null},"file":{"path":"articles/游戏开发专题/13游戏跨服架构进化之路.md","mtime":"2020-10-07T16:03:27.577Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-10-09T15:31:57.905Z"},"basePath":"../..","book":{"language":""}});
		});
	</script>
</div>

        
    <script src="../../gitbook/gitbook.js"></script>
    <script src="../../gitbook/theme.js"></script>
    
        
        <script src="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-search-pro/search.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-back-to-top-button/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-hide-element/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-code/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-livereload/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-theme-fexa/fexa.js"></script>
        
    

    </body>
</html>

